一、介绍
角色就是相关权限的命令集合,使用角色的主要目的就是为了简化权限的管理。
假定有用户a,b,c为了让他们都拥有如下权限
1. 连接数据库
2. 在scott.emp表上select,insert,update。
如果采用直接授权操作,则需要进行12次授权。
因为要进行12次授权操作,所以比较麻烦喔!怎么办?
如果我们采用角色就可以简化:
首先将creat session,select on scott.emp, insert on scott.emp, update on scott.emp 授予角色,然后将该角色授予a,b,c 用户,这样就可以三次授权搞定。

二、角色分为预定义和自定义角色两类

三、预定义角色
预定义角色是指oracle所提供的角色,每种角色都用于执行一些特定的管理任务,下面我们介绍常用的预定义角色connect、resource、dba。
1)、connect角色
connect角色具有一般应用开发人员需要的大部分权限,当建立了一个用户后,多数情况下,只要给用户授予connect和resource角色就够了,那么connect角色具有哪些系统权限呢?
create cluster
create database link
create session
alter session
create table
create view
create sequence

2)、resource角色
resource角色具有应用开发人员所需要的其它权限,比如建立存储过程,触发器等。这里需要注意的是resource角色隐含unlimited tablespace系统权限。
resource角色包含以下系统权限:
create cluster
create indextype
create table
create sequence
create type
create procedure
create trigger

3)、dba角色
dba角色具有所有的系统权限,及with admin option选项,默认的dba用户为sys和system,它们可以将任何系统权限授予其他用户。但是要注意的是dba角色不具备sysdba和sysoper的特权(启动和关闭数据库)。

四、自定义角色
1、顾名思义就是自己定义的角色,根据自己的需要来定义。一般是dba来建立,如果用别的用户来建立,则需要具有create role的系统权限。在建立角色时可以指定验证方式(不验证,数据库验证等)。
1)、建立角色(不验证)
如果角色是公用的角色,可以采用不验证的方式建立角色。
create role 角色名 not identified;
2)、建立角色(数据库验证)
采用这样的方式时,角色名、口令存放在数据库中。当激活该角色时,必须提供口令。在建立这种角色时,需要为其提供口令。
create role 角色名 identified by 密码;

2、角色授权
1)、给角色授权
给角色授予权限和给用户授权没有太多区别,但是要注意,系统权限的unlimited tablespace和对象权限的with grant option选项是不能授予角色的。
SQL> conn system/oracle;
SQL> grant create session to 角色名 with admin option
SQL> conn scott/oracle@orcl;
SQL> grant select on scott.emp to 角色名;
SQL> grant insert, update, delete on scott.emp to 角色名;
通过上面的步骤,就给角色授权了。

2)、分配角色给某个用户
一般分配角色是由dba来完成的,如果要以其它用户身份分配角色,则要求用户必须具有grant any role的系统权限。
SQL> conn system/oracle;
SQL> grant 角色名 to blake with admin option;
因为我给了with admin option选项,所以,blake可以把system分配给它的角色分配给别的用户。

3、删除角色
使用drop role,一般是dba来执行,如果其它用户则要求该用户具有drop any role系统权限。
SQL> conn system/oracle;
SQL> drop role 角色名;
问题:如果角色被删除,那么被授予角色的用户是否还具有之前角色里的权限?
答案:不具有了

4、显示角色信息
1)、显示所有角色
SQL> select * from dba_roles;
2)、显示角色具有的系统权限
SQL> select privilege, admin_option from role_sys_privs where role='角色名';
3)、显示角色具有的对象权限
通过查询数据字典视图dba_tab_privs可以查看角色具有的对象权限或是列的权限。
4)、显示用户具有的角色,及默认角色
当以用户的身份连接到数据库时,oracle 会自动的激活默认的角色,通过查询数据字典视图dba_role_privs 可以显示某个用户具有的所有角色及当前默认的角色。
SQL> select granted_role, default_role from dba_role_privs where grantee = ‘用户名’;

五、精细访问控制
精细访问控制是指用户可以使用函数,策略实现更加细微的安全访问控制。如果使用精细访 问控制,则当在客户端发出sql语句(select,insert,update,delete)时,oracle会自动在sql语句后追加谓词 (where子句),并执行新的sql语句,通过这样的控制,可以使得不同的数据库用户在访问相同表时,返回不同的数据信息,如:
用户 scott blake jones
策略 emp_access
数据库表 emp
如上图所示,通过策略emp_access,用户scott,black,jones在执行相同的sql语句时,可以返回不同的结果。
例如:当执行select ename from emp时,根据实际情况可以返回不同的结果。

转载于:https://www.cnblogs.com/Lightning-Kid/p/3863353.html

十八、oracle 角色相关推荐

  1. 燕十八PHP高性能架构班Oracle部分课程

    课程简介: 本课程为燕十八老师的燕十八PHP高性能架构班内的Oracle教程,众所周知,燕十八老师的讲课风格都是一种幽默易懂深受学生喜欢,本部分课程依然继承了这种风格.本部分课程通过31课来讲解Ora ...

  2. 三十八载,Oracle伴我同行—记我的职业成长之路

    2015年7月19日 三十八载 Oracle伴我同行 --记我的职业成长之路 2015,今年是Oracle公司38周年:2015,今年我已然38岁.在Oracle庆祝38岁生日之际,仅以此文作为回 ...

  3. Oracle数据库从入门到精通系列之十八:Oracle进程

    Oracle数据库从入门到精通系列之十八:Oracle进程 一.Oracle进程 二.服务器进程server process 三.后台进程background process 四.从属进程(slave ...

  4. 设计模式 ( 十八 ) 策略模式Strategy(对象行为型)

    设计模式 ( 十八 ) 策略模式Strategy(对象行为型) 1.概述 在软件开发中也经常遇到类似的情况,实现某一个功能有多种算法或者策略,我们能够依据环境或者条件的不同选择不同的算法或者策略来完毕 ...

  5. 数据库51年来十八件大事年表

    数据库51年来十八件大事年表 数据库经历了这么多年,它的历史你知道多少 1961年:通用电气着手开发Integrated Data Store(IDS,集成数据存储).通常来讲,IDS被认为是第一个& ...

  6. 【Visual C++】游戏开发四十八 浅墨DirectX教程十六 三维地形系统的实现

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 本系列文 ...

  7. 第十六讲:完美主义身心健康 第十七讲:身心健康:运动与冥想 第十八讲:睡眠,触摸和爱情的重要性

    (注:此为课程第十六课,更新于2017年6月29日) 早上好! 我们今天要把完美主义讲完,然后开始讲精神肉体(Mind and Body).这个学期对我来说挺不错的,基本上没有什么东西让我后悔做过.不 ...

  8. CSDN 编程竞赛二十八期题解

    竞赛总览 CSDN 编程竞赛二十八期:比赛详情 (csdn.net) 本期竞赛的题目都很简单,但是非常考验读题和编码速度.这一次没有遇到bug,竞赛体验较好. 竞赛题解 题目1.小Q的鲜榨柠檬汁 团建 ...

  9. 辽河十八汊最牛X男爷们

    辽河十八汊最牛X男爷们 这是一个极其清晰而色彩瑰丽的梦,昨天上午睡觉的时候做的. 在梦里,小关同学跟我说,"老师,我带你去听一个老师的课."然后用表情淋漓 尽致地形容了这是一位多么 ...

  10. 燕十八PHP高性能架构班教学视频教程

    彻底拿下Linux集群+Nginx高并发+lvs负载均衡+MySQL优化+NoSQL! 2000W万条真实网站数据,拒绝纸上谈兵! Linux资深运维 + 燕十八老师亲自授课! Linux优化篇1.m ...

最新文章

  1. 经常误提交.DS_Store文件怎么办?Git全局排除配置了解一下!
  2. 面试真题:搜索旋转数组
  3. ua获取手机型号_取证人员为什么很难从移动设备上获取电子数据证据?
  4. unity 解决乱码_Unity3d中IOS应用出现乱码怎么办?
  5. freebsd 手工安装zabbix2.0 php,zabbix 服务端,子客户端安装配置日志
  6. mysql基础命令大全
  7. mongodb json_在MongoDB和Spring Batch中将XML转换为JSON和原始使用
  8. as工程放到源码编译_Flutter源码剖析(二):源码的阅读与调试环境配置
  9. 2-自定义 Mybatis 框架
  10. 在页面加载完后执行javascript代码
  11. php管理系统模板,自定义模块后台模板
  12. sql查询时取日期部分内容(年月日时分秒)、增加时间
  13. CUDA/CUDNN下载安装以及适配pytorch和tensorflow
  14. [Protues]protues8使用示波器制作李沙育图形
  15. 华为Eudumon1000配置PORTAL认证
  16. 掌握技巧可以快速完成网站备案
  17. 转载:Think in AngularJS:对比jQuery和AngularJS的不同思维模式(大漠穷秋)
  18. 小爱控制HA上的开关(红外线)
  19. Photoshop CS6 Extended 特别版特点介绍
  20. C,D,Go,Rust,Nim,Zig,V,Julia,Py,C#,Kotlin 11语回文数大战!仅供娱乐参考!

热门文章

  1. 竞赛中如何做特征工程
  2. 吴忠强:刷LeetCode的正确姿势!
  3. CNN 分类古代陶器,表现超过考古专家,解决“考古学中的肮脏秘密”
  4. AI语音独角兽思必驰完成数亿元Pre-IPO融资,冲刺苏州AI创业第一股
  5. 模型部署神器:高中生也能读懂的Docker入门教程
  6. 哈佛大学校长: 教育是培养你辨别有人在胡说八道的能力
  7. 山东大学教授建议:让博士生先回学校
  8. 用Python做一个翻译软件,还怕英语不好?
  9. Python3.5源码分析-内存管理
  10. Python源码学习:启动流程简析