设为首页 收藏本站
查看: 778|回复: 0

[经验分享] Oracle系列:(26)用户权限控制

[复制链接]

尚未签到

发表于 2018-9-7 12:15:15 | 显示全部楼层 |阅读模式
  1、用户
  Oracle中的用户分为二大类
  1)Oracle数据库服务器创建时,由系统自动创建的用户,叫系统用户,如sys。
  2)利用系统用户创建的用户,叫普通用户,如scott,hr,c##tiger,zhaojun,...
  》用sys登录,查询当前Oracle数据库服务器中已有用户的名字和状态
  username表示登录名
  expired&locked表示帐号过期和锁定
  open表示帐号现在可用
  sqlplus / as sysdba;  
  col username for a30;
  
  col account_status for a30;
  
  set pagesize 100;
  
  select username,account_status from dba_users;
DSC0000.jpg

  查询Oracle中有哪些用户
  select * from all_users;
DSC0001.jpg

  2、创建与删除普通用户
  可以在Oracle中创建新的普通用户,创建普通用户命令是:create user,在创建普通用户的同时,应该为其分配一个具体的表空间,通常叫users。
  》用sys登录,查询Oracle中有哪些可用存储空间,所有普通用户默认为users存储空间
  select * from v$tablespace;
DSC0002.jpg

DSC0003.jpg

  》用sys登录,创建普通用户c##tiger,密码为abc,默认使用users存储空间,即对应硬盘上的一个DBF二进制文件
  sqlplus / as sysdba;  
  create user c##tiger identified by abc default tablespace users;
  》用sys登录,为c##tiger分配users空间无限制使用,即数据库中DBF文件可以无限增加,一个DBF文件不够,会创建第二个DBF文件
  sqlplus / as sysdba;  
  alter user c##tiger quota unlimited on users;
DSC0004.jpg

  》用c##tiger登录,能进orcl数据库吗?
  sqlplus c##tiger/abc  进不去orcl数据库
  》用sys登录,删除普通用户c##tiger
  sqlplus / as sysdba;  
  drop user c##tiger cascade;
  3、了解系统用户
  sys是Oracle中一个重要的系统用户,sys是Oracle中最高权限用户,其角色为SYSDBA(系统管理员)
sqlplus / as sysdba  4、权限
  权限的最终作用于用户。即所有用户在数据库内的操作对象和可执行的动作都是受到限制的。
  Oracle中权限分为二大类:
  1)系统权限
  2)对象权限
  4.1、系统权限
  针对数据库中特定操作的许可,例如:让c##tiger能登录到orcl数据库,能在orcl数据库中创建表
  》用sys登录,获取系统权限的相关信息,例如:select any table表示针对所有表的select权限
  sqlplus / as sysdba;  
  select distinct privilege from dba_sys_privs;
DSC0005.jpg

  》用sys登录,为c##tiger分配create session与数据库建立会话的权限,即允许该用户登录
  sqlplus / as sysdba;  
  grant create session to c##tiger;
DSC0006.jpg

  》用c##tiger登录,能进orcl数据库吗?
  sqlplus c##tiger/abc  能进去orcl数据库
  》用c##tiger登录,创建一张tiger的表,能创建吗?
  sqlplus c##tiger/abc  
  create table tiger(
  
    name varchar2(20)
  
  );
  这时c##tiger没有权限创建表
DSC0007.jpg

  》用sys登录,为c##tiger分配create table权限,即允许创建表
  sqlplus / as sysdba;  
  grant create table to c##tiger;
  》用c##tiger登录,创建一张tiger的表,能创建吗?
  sqlplus c##tiger/abc  
  create table tiger(
  
    name varchar2(20)
  
  );
  可以创建c##tiger表
  》用sys登录,查询c##tiger所拥有的系统权限
  sqlplus / as sysdba;
  select grantee,privilege from dba_sys_privs where lower(grantee) = 'c##tiger';  grantee表示普通用户名
  privilege权限名
DSC0008.jpg

  》用sys登录,撤销c##tiger的create table权限
  sqlplus / as sysdba;  
  revoke create table from c##tiger;
  4.2、对象权限
  用户对已有对象的操作权限,包括:
  1)select可用于表,视图和序列
  2)insert向表或视图中插入新的记录
  3)update更新表中数据
  4)delete删除表中数据
  5)execute函数,过程的执行
  6)index为表创建索引
  7)references为表创建外健
  8)alter修改表或者序列的属性
  》用sys登录,查询c##tiger所拥有的对象权限
  sqlplus / as sysdba;  
  col grantee for a10;
  
  col table_name for a10;
  
  col privilege for a20;
  
  select grantee,table_name,privilege from dba_tab_privs where lower(grantee) = 'c##tiger';
  》用sys登录,为c##tiger分配对tiger表的所有权限,即增删改查操作
  sqlplus / as sysdba;  
  grant all on c##tiger.tiger to c##tiger;
  注意:c##tiger表示空间名
  tiger表示该空间下的表名
  C##TIGER   TIGER      FLASHBACK
  C##TIGER   TIGER      DEBUG
  C##TIGER   TIGER      QUERY REWRITE
  C##TIGER   TIGER      ON COMMIT REFRESH
  C##TIGER   TIGER      REFERENCES
  C##TIGER   TIGER      UPDATE
  C##TIGER   TIGER      SELECT
  C##TIGER   TIGER      INSERT
  C##TIGER   TIGER      INDEX
  C##TIGER   TIGER      DELETE
  C##TIGER   TIGER      ALTER
DSC0009.jpg

  》用c##tiger登录,对tiger表进行增删改查操作
  sqlplus c##tiger/abc;  
  insert into tiger(name) values('AA');
  
  update tiger set name = 'BB';
  
  delete from tiger where rownum = 1;
  
  select * from tiger;



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-566054-1-1.html 上篇帖子: MyBatis系列:(9)mybatis-spring-springmvc-oracle/mysql整合 下篇帖子: Oracle系列:(27)小结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表