添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

oracle 对象的授权
Oracle
授权

一、授权语法
GRANT 语法:

1. 显式授权 ( 直接将对象授权给用户 )
GRANT privilege [, ...] ON object [, ...]  TO  { Public| Group | Username|role} [WITH GRANT OPTION ]
例子
grant read,write on directory dir_home to public
2.
隐式授权 ( 通过将角色授权给用户
)
GRANT role TO  { Public| Group | Username|role}

例子 grant connect,resource to oltp_user

语法说明:

privilege ( 权限 )
可能的权限有:

SELECT--
访问声明的表 / 视图的所有列 / 字段.

INSERT—
对声明的表插入所有列 / 字段.
UPDATE—
对声明的表更新所有列 / 字段.
DELETE--
对声明的表删除所有列 / 字段.
RULE --
/ 视图上定义规则 (参见 CREATE RULE 语句).
ALL --
赋予所有权限.

object 赋予权限的对象名.
可能的对象是:
table
(表)

view
(视图)

sequence
(序列)

index
(索引)

directory (目录)
Public
代表是所有用户的简写.
Group
将要赋予权限的组 GROUP .目前的版本中,组必须是用下面方法显式创建的.

Username
将要赋予权限的用户名. PUBLIC 是代表所有用户的简写.

role
某个角色, ( DBA connect resource)
WITH GRANT OPTION
允许向别人赋予同样权限 , 被授权的用户可以继续授权
.
描述

对象创建后,除了创建者外,除非创建者赋予( GRANT )权限,其他人没有访问对象的权限。
GRANT
允许对象的创建者给某用户或某组或所有用户( PUBLIC )某些特定的权限。不需要给创建者赋予( GRANT )对象的权限,创建者默认拥有对象的所有权限,包括删除它的权限。

Oracle 不允许在存储过程中使用未经显式授权的对象 . 要使用另一用户的对象,必须通过另一用户给自己显示授权。

因为 Oracle 在编译存储过程时并不检查定义者拥有的角色,只是检查其被显式授予的权限, DBA 也是一种角色,所以即使是 DBA ,也需要显式授权

二、授权方式 ( 显式和隐式 )

对象授权有两种模式 , 显式和隐式 :
显示授权和隐式授权的区别是:显式授权是直接把对象授权给用户,隐式授权是给用户授予角色的方式来实现授权。

1. 显式授权是直接用 GRANT 语句进行授权。
语法: GRANT 某种权限 TO 用户
:
CONN  USER1/Password
GRANT SELECT  ON TABLE1 TO USER2;
user1 的表 TABLE1 select 权限显示授权给 user2
GRANT UPDATE  ON TABLE1 TO USER2; user1 的表 TABLE1 update 权限显示授权给 user2


注:用 system/manager 登录是没法授权的,要使 USER2 用户能在存储过程里面访问 USER1 用户的表,必须以 USER1 用户 ( 该用户有 dba 权限 ) 登录,然后授权就可以了。
SQL>grant select on USER1.MA_USERINFO to USER2

2. 隐式授权则是通过 ROLE 来授权。
语法: GRANT 某个角色 TO 用户
:
CONN  USER1
GRANT SELECT ON TABLE1 TO ROLE1;
USER1 的表 TABLE1 select 权限显示授权给 Role1
CONN  SYSTEM 切换成管理员授予角色
GRANT ROLE1 TO USER2;
USER2 授与 Role1 的权限。


三、收回权限
语法:
显式收权: revoke 权限 from 用户 ; 从用户中收回权限

隐式收权: Revoke 角色 from 用户 ; 从用户中收回角色

revoke  privilege1 from USER2; 从用户中收回权限

revoke select on table1 from User1; 收回查询 select 表的权限
revoke all on table1 from User1; 从用户 user1 中收回表 table1 的所有权限

revoke  ROLE1    from USER2; 从用户中收回角色
grant  connect to xujin;
对用户 xujin 授予 connect 角色
revoke connect  from xujin 从用户 xujin 收回 connect 角色

Leonarding

2012.2.9

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26686207/viewspace-715992/,如需转载,请注明出处,否则将追究法律责任。 刘盛,香港城市大学EMBA,现担任中国民生银行民生科技供应链金融事业部负责人,负责企业生态业务发展工作。 2016年8月12日刘盛受邀参加了由磐岩智慧在上海绿地万豪大酒店主办的“全球互联网金融创新论坛2016”,并作了“中国互联网金融信用体系建设与未来”主题演讲。

注册时间: 2012-02-10

3309027

广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员