Oracle系统权限与对象权限
oracle权限分为:
系统权限: 允许用户执行特定的数据库动作,如创建表、创建索引、连接实例等。
对象权限: 允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等。
系统权限
超过一百多种有效的权限(查询约209种)
SQL> select count(*) from system_privilege_map; COUNT(*)
----------
209
数据库管理员具有高级权限以完成管理任务,例如:
– 创建新用户
– 删除用户
– 删除表
– 备份表
常用的系统权限:
create session 创建会话
create sequence 创建序列
create synonym 创建同名对象
create table 在用户模式中创建表
create any table 在任何模式中创建表
drop table 在用户模式中删除表
drop any table 在任何模式中删除表
create procedure 创建存储过程
execute any procedure 执行任何模式的存储过程
create user 创建用户
drop user 删除用户
create view 创建视图
授予系统权限
grant privilege [, privilege...] to user [, user| role, public...] [with admin option];
选项:
public 所有用户都有的角色
with admin option 使用户同样具有分配权限的权利,可将此权限授予别人
授予系统权限
1、创建用户...
2、授权
例:
链接到会话,创建表
grant create session,create table to test01;
创建表并且可以授权其他用户
grant create session to test01 with admin option;
注:
1)如果使用WITH ADMIN OPTION为某个用户授予系统权限,那么对于被这个用户授予相同权限的所有用户来说,取消该用户的系统权限并不会级联取消这些用户的相同权限。
2)系统权限无级联,即A授予B权限,B授予C权限,如果A收回B的权限,C的权限不受影响;系统权限可以跨用户回收,即A可以直接收回C用户的权限。
执行任意存储过程权限
grant execute any procedure to test01;
注: execute any procedure 不能和 create any procedure 授权统一普通用户
授权所有用户dba
grant dba to public --不能做的哈。。
移除所有用户的dba权限
revoke dba from public --不能做的哈。
使用系统权限
创建test用户,默认表空间test,授权创建会话、链接数据库权限
create user test identified by test default tablespace test; grant create session,connect to test;
使用表空间权限
grant unlimited tablespace to test; --授权可以使用默认表空间的权限 conn itpux/itpux --链接会话 create table itpuxt1 as select * from user_tables; --在默认表空间创建表
显示系统权限
dba_sys_privs --针对所有用户被授予的系统权限
user_sys_privs --针对当前登陆用户被授予的系统权限
查看所有系统权限:
select * from system_privilege_map;
显示用户所具有的系统权限:
select * from dba_sys_privs;
显示当前用户所具有的系统权限:
select * from user_sys_privs;
显示当前会话所具有的系统权限:
select * from session_privs;
在sys用户下查TEST用户的权限
select * from dba_sys_privs where grantee='TEST'; select * from dba_sys_privs where grantee in ('TEST','SYSTEM') ; select * from dba_sys_privs where grantee in ('TEST','SYSTEM') order by grantee ;
收回系统权限
赋予系统权限
grant create table to test;
收回赋予的系统权限
revoke create table from test;
注意:对于使用with admin option 为某个用户授予系统权限,那么对于被这个用户授予相同权限的所有用户来说,取消该用户的系统权限并不会级联取消这些用户的相同权限
对象权限
不同的对象具有不同的对象权限
对象的拥有者拥有所有权限
对象的拥有者可以向外分配权限
oracle一共有8种对象权限
对象授权
grant object_priv|all [(columns)] on object to {user|role|public} [with grant option];
all:所有对象权限
public:授给所有的用户
with grant option:允许用户再次给其它用户授权
conn /as sysdba; grant select on scott.emp to test; --授权test查找scott.emp表的权限 grant select on scott.emp to public; --授权所有用户查找scott.emp表的权限 grant update(sal,mgr) on scott.emp to test with grant option; conn itpux/itpux select * from scott.emp; update scott.emp set sal=sal+100;
授予系统权限与授予对象权限的语法差异:
授予对象权限时需要指定关键字on,从而能够确定权限所应用的对象, 对于表和视图可以指定特定的列来授权。
查询权限分配情况
-- 数据字典视图
role_sys_privs role_tab_privs
user_tab_privs_made
user_tab_privs_recd
user_col_privs_made
user_col_privs_recd
user_sys_privs
user_tab_privs
user_role_privs
查询已授予的对象权限(即某个用户对哪些表对哪些用户开放了对象权限)
sql> conn scott/scott sql> select * from user_tab_privs_made; --下面是scott用户开放的对象权限
查询列上开放的对象权限
sql> select * from user_col_privs_made;
查询已接受的对象特权(即某个用户被授予了哪些表上的哪些对象特权)
sql> select * from user_tab_privs_recd;
查询用户已接受列的对象权限
sql> select * from user_col_privs_recd;
收回对象权限
使用revoke 语句收回权限
使用with grant option 子句所分配的权限同样被收回
revoke {privilege [, privilege...]|all} --on object --from {user[, user...]|role|public} -- [cascade constraints];--收回权限
cascade constraints
为处理引用完整性时需要
对于要回收查询/修改列的权限,可以直接怼表级进行回收,不需要到具体列。
SQL> conn /as sysdba; Connected. SQL> revoke select on scott.emp from test; Revoke succeeded. SQL> revoke update(sal,mgr) on scott.emp from test; revoke update(sal,mgr) on scott.emp from test * ERROR at line 1: ORA-01750: UPDATE/REFERENCES may only be REVOKEd from the whole table, not by column SQL> revoke update on scott.emp from test; Revoke succeeded.
其它
检查dba权限的用户
select * from dba_role_privs where granted_role='dba';
查看用户具有的系统权限:
select * from session_privs;
总结
使用create user语句创建用户,alter user语句修改用户,其语法大致相同 drop user username [cascade] 会删除用户所拥有的所有对象及数据。
系统权限允许用户在数据库中执行特定的操作,如执行ddl语句。
with admin option 使得该用户具有将自身获得的权限授予其它用户的功能。 但收回系统权限时,不会从其它帐户级联取消曾被授予的相同权限。
对象权限允许用户对数据库对象执行特定的操作,如执行dml语句。
with grant option 使得该用户具有将自身获得的对象权限授予其它用户的功能 但收回对象权限时,会从其它帐户级联取消曾被授予的相同权限。
系统权限与对象权限授予时的语法差异为对象权限使用了on object_name 子句。
public 为所有的用户
all:对象权限中的所有对象权限
Oracle系统权限与对象权限的更多相关文章
- Oracle 用户、角色、权限(系统权限、对象权限)的数据字典表
1 三者的字典表 1.1 用户 select * from dba_users; select * from all_users; select * from user_users; 1.2 角色 s ...
- 如何Oracle查出一个用户具有的所有系统权限和对象权限
1. 系统权限 SELECT * FROM DBA_SYS_PRIVS WHERE GRANTEE = 'LCAM_SYS_1216' UNION ALL SELECT * FROM DBA_SYS_ ...
- 16Oracle Database 系统权限和对象权限
Oracle Database 系统权限和对象权限 Oracle中的系统权限和对象权限 DCL 数据控制语言 -- 查看对象的权限 grant / revoke 查看登录用户 Show user 查看 ...
- [oracle] 两种权限:系统权限VS对象权限
系统权限表示对表和表空间等 有无操作权 的权限.一般是SYS用户这种DBA来授权.比如: grant create session to lisi grant create table to l ...
- Oracle 用户、对象权限、系统权限
--================================ --Oracle 用户.对象权限.系统权限 --================================ 一.用户与模式 ...
- oracle新建对象 权限管理
代码 CREATE USER target IDENTIFIED BY target ; GRANT CONNECT, RESOURCE TO target; 刚刚创建的oracle实例中会内建两个用 ...
- SQL Fundamentals || DCL(Data Control Language) || 系统权限&对象权限管理(GRANT&REVOKE)
SQL Fundamentals || Oracle SQL语言 语句 解释 Create user Creates a user(usually performed by a DBA) Grant ...
- Oracle基础(五) 权限管理
一.数据库权限分类 权限是指用户对某个功能是否具有执行的权利.在Oracle中,权限分为系统权限和对象权限. 1.系统权限 系统规定用户使用数据库的权限.例如创建表空间,创建表,删除表的权利.这些都属 ...
- Oracle 表空间和用户权限管理【转】
一. 表空间 Oracle数据库包含逻辑结构和物理结构. 数据库的物理结构指的是构成数据库的一组操作系统文件. 数据库的逻辑结构是指描述数据组织方式的一组逻辑概念以及它们之间的关系. 表空间是数据库逻 ...
随机推荐
- CSP-S 模拟53 题解
题解: T1 u: 一看到修改这么多,但询问其实只有一个不难想到差分,但是他这个形状可以说很不规则,于是我们想到分别维护竖着的和斜着的差分,然后最后合并即可. 考场上瞎调了一波系数莫名AC,其实是维护 ...
- 【luoguP5550】Chino的数列
题目背景 没有背景 我写不出来了qwq 题目描述 Chino给定了nn个数a_1...a_na1...an,给定常数s,m,她会轮流对这nn个数做k组操作,每组操作包含以下几步: 1.swap(a ...
- 刚注册blog,先来刷个存在
我想以后能够走数字ic设计的道路,努力复习考研,努力提升专业素养,2017加油!青春加油!
- 关于centos6版本执行程序报错:libc.so.6: version GLIBC_2.14 not found的解决
执行后程序报错: libc.so.6: version GLIBC_2.14 not found 这种情况是因为当前服务器glibc的版本比较低造成的(不出意外是glibc_2.12是最高版本): 1 ...
- TCP报头格式
1.端口号:用来标识同一台计算机的不同的应用进程. 1)源端口:源端口和IP地址的作用是标识报文的返回地址. 2)目的端口:端口指明接收方计算机上的应用程序接口. TCP报头中的源端口 ...
- java线程基础方法详解
一.线程状态转换 1.新建状态(New):新创建了一个线程对象. 2.就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法.该状态的线程位于可运行线程池中,变得可运行 ...
- PHP 二维数组去重方法
php二维数组的去重策略,如果需要根据某字段去重(其他字段可能不一致),那么需要使用循环策略,如果去重的都是相同的(字段,值),那么可以用序列化方式. $allComments = array_map ...
- js实现简单的文件上传
文件下载:https://www.cnblogs.com/xiaomili/p/10521160.html html: <form name="form1" id=&quo ...
- python3.6 列表推导式学习
a=[i for i in range(1,10) if i%2==0]print(a)c=[(x,y) for x in range(5) if x%2==0 for y in range(5) i ...
- Oracle Database的基本概念
一个 Oracle 服务器:是一个关系数据库管理系统(RDBMS),它提供全面的, 近乎完整的信息管理由Oracle 实例和Oracle 数据库组成Oracle 数据库 和 Oracle 实例Orac ...