oracle授权操作

1、给数据库用户授权(对象为用户表)

GRANT privilege[, ...] ON object[, ...] TO { PUBLIC | GROUP group| username}

详解:
privilege:
select:查询
insert:插入
update:更新
delete:删除
all:所有

--给所有用户授予查询、插入、更新tablename表的权限
grant select,insert,update on tablename to public;

--收回所有用户查询、插入、更新tablename表的权限
revoke select,insert,update on tablename from public;

详解:
object:
table:表
view:视图
sequence:序列
index:索引

举例说明:

grant select,insert,update on tablename,viewname,sequencename,indexname to public;  

public:对所有用户开放权限
GROUP groupname:对该组所有用户开放权限
username:对指定用户开放权限

2、给数据库用户授权(对象多为系统表,如dba可以查看

--创建用户语句:
create user[用户名] identified by password[密码];

--创建后一定要给用户授权:(这里给个登录授权)
grant connect to user[用户名];    

--撤销用户权限
revoke connect from user[用户名];

--查看指定用户有哪些系统权限
select * from dba_role_privs where grantee=upper('username');

--查看指定用户有哪些对象权限
select * from dba_tab_privs where grantee=upper('username');

可能遇到问题:
1、当在一个新建数据库用户上创建表失败时,可以查看系统权限
在当前用户执行select * from dba_role_privs where grantee=upper(‘username’);如果不能执行(提示表或视图不存在),说明没有dba权限
解决方法:可以登录sys账户赋予dba权限
登录sys:sqlplus / as sysdba
给username赋权限:grant dba to username;

权限相关的查询和赋予:
所有权限的赋予均是在有赋予权限的用户下进行,此处授权用户都是sys用户
1、select * from dba_role_privs where grantee=upper(‘luyongpeng’);
其中,admin_option是通过在授权时添加with admin option 选项定义
grant dba to luyongpeng with admin option;//admin_option为YES,如果不加with admin option 选项,则admin_option为NO
使用grant dba to luyongpeng;无法覆盖之前的权限
但grant dba to luyongpeng with admin option 可以覆盖grant dba to luyongpeng;的权限

你可能感兴趣的:(oracle)