Oracle用户与对象权限与系统权限.docx

上传人:b****1 文档编号:2643473 上传时间:2023-05-04 格式:DOCX 页数:17 大小:19.23KB
下载 相关 举报
Oracle用户与对象权限与系统权限.docx_第1页
第1页 / 共17页
Oracle用户与对象权限与系统权限.docx_第2页
第2页 / 共17页
Oracle用户与对象权限与系统权限.docx_第3页
第3页 / 共17页
Oracle用户与对象权限与系统权限.docx_第4页
第4页 / 共17页
Oracle用户与对象权限与系统权限.docx_第5页
第5页 / 共17页
Oracle用户与对象权限与系统权限.docx_第6页
第6页 / 共17页
Oracle用户与对象权限与系统权限.docx_第7页
第7页 / 共17页
Oracle用户与对象权限与系统权限.docx_第8页
第8页 / 共17页
Oracle用户与对象权限与系统权限.docx_第9页
第9页 / 共17页
Oracle用户与对象权限与系统权限.docx_第10页
第10页 / 共17页
Oracle用户与对象权限与系统权限.docx_第11页
第11页 / 共17页
Oracle用户与对象权限与系统权限.docx_第12页
第12页 / 共17页
Oracle用户与对象权限与系统权限.docx_第13页
第13页 / 共17页
Oracle用户与对象权限与系统权限.docx_第14页
第14页 / 共17页
Oracle用户与对象权限与系统权限.docx_第15页
第15页 / 共17页
Oracle用户与对象权限与系统权限.docx_第16页
第16页 / 共17页
Oracle用户与对象权限与系统权限.docx_第17页
第17页 / 共17页
亲,该文档总共17页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

Oracle用户与对象权限与系统权限.docx

《Oracle用户与对象权限与系统权限.docx》由会员分享,可在线阅读,更多相关《Oracle用户与对象权限与系统权限.docx(17页珍藏版)》请在冰点文库上搜索。

Oracle用户与对象权限与系统权限.docx

Oracle用户与对象权限与系统权限

1用户与模式

用户:

对数据库的访问,需要以适当用户身份通过验证,并具有相关权限来完成一系列动作

SYS用户,缺省始终创建,且未被锁定,拥有数据字典及其关联的所有对象

SYSTEM用户,缺省始终创建,且未被锁定,可以访问数据库内的所有对象

 模式(schema):

是某个用户拥有所有对象的集合。

具有创建对象权限并创建了对象的用户称为拥有某个模式 

注意:

创建数据库对象(视图,表等)的任一用户都拥有一个以该用户名称开头的模式,且被视为模式用户

2创建及修改用户

条件:

需要具有创建用户的权限,如sys,system,sysdba,dbarole等

   语法:

 

       CREATEUSERuser

        IDENTIFIED{BYpassword|EXTERNALLY|GLOBALLYASexternalname}

       [DEFAULTTABLESPACEtablespace_name]

       [TEMPORARYTABLESPACEtablespace_name]

       [QUOTA{n{[K|M]|UNLIMITED}ONtablespace_name

        QUOTA{n{[k|M]|UNLIMITED}ONtablespace_name...]

       [PASSWORDEXPIRE]

       [ACCOUNT{LOCK|UNLOCK}]

       [PROFILE{profile_name|DEFAULT}]

 

    eg:

    CREATE USER  robinsonIDENTIFIED BY  tiger;

   

        --省略了DEFAULTTABLESPACE和TEMPORARYTABLESPACE 时,则由database_properties中对应的参数确定

       SQL> SELECT property_name,property_value FROM database_properties WHERE property_name LIKE 'DEFAULT%';

 

       PROPERTY_NAME                  PROPERTY_VALUE

       --------------------------------------------------------------------------------

       DEFAULT_TEMP_TABLESPACE        TEMP

       DEFAULT_PERMANENT_TABLESPACE   USERS

       DEFAULT_TBS_TYPE               SMALLFILE

   

        更多关于表空间的请参考:

Oracle 表空间与数据文件      

    1.修改用户

        修改用户的语法同创建用户,仅仅讲关键字create替换为alter,alteruser可以修改除用户名之外的任一属性

       ALTER USER robinsonACCOUNTLOCK;

   

    2.修改密码

       DBA 可以创建用户和修改密码

       用户本人可以使用ALTERUSER 语句修改密码

       SQL> ALTER robinson  IDENTIFIED BY  newpassword;

 

    3.删除用户:

       DROP USER username[CASCADE]

 

       CASECADE 连同用户创建的对象一并删除,如果该用户创建了对象,要加CASCADE删除,否则删除不掉

       另外,不能删除当前正在与ORACLE服务器相连的用户。

   

    4.改变用户在表空间上的配额:

       ALTER USER username  QUOTA0 ON system;

       ALTER USER scottQUOTAUNLIMITED ON USERS;

       ALTER USER dogQUOTA30M ON system;

 

    5.查看用户表空间配额(dba_ts_quotas):

       SQL> SELECT USERNAME,TABLESPACE_NAME,MAX_BYTES/1024/1024"MaxMB"     

         2  FROM dba_ts_quotas WHERE USERNAME='SCOTT';

 

       USERNAME              TABLESPACE_NAME           Max MB

       --------------------------------------------------------

       SCOTT                 SYSTEM                     30

   

    6.查看特定对象下用户所拥有的对象

       使用dba_objects视图

       SQL> SELECT owner,object_name, object_type FROM dba_objects WHERE owner= 'SCOTT';

3Oracle权限

系统权限:

 允许用户执行特定的数据库动作,如创建表、创建索引、连接实例等

对象权限:

 允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等

3.1系统权限

   超过一百多种有效的权限(SELECT * FROM SYSTEM_PRIVILEGE_MAP查)

       数据库管理员具有高级权限以完成管理任务,例如:

           –创建新用户

           –删除用户

           –删除表

           –备份表

          

a.常用的系统权限:

       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                        创建视图

 

 

    b.授予用户系统权限

       GRANT privilege[,privilege...] TO user [,user|role,PUBLIC...]

       [WITHADMINOPTION];

 

       PUBLIC     所有用户

       WITHADMINOPTION 使用户同样具有分配权限的权利,可将此权限授予别人

      

           SQL> GRANT CREATE SESSION,CREATE TABLE,CREATE USER TO scott;

           SQL> GRANT EXECUTE ANY PROCEDURE TO scott WITH ADMIN OPTION;

           SQL> CONNscott;    --scott具有WITHADMINOPTION,故可以将EXECUTEANYPROCEDURE授予robinson

           Enterpassword:

           Connected.

           SQL> GRANT EXECUTE ANY PROCEDURE TO robinson;

          

           Grant succeeded.

           SQL> GRANT EXECUTE ANY PROCEDURE TO PUBLIC; --将EXECUTEANYPROCEDURE授予所有用户

 

           Grant succeeded.

           SQL> CONNsystem/redhat;  --使用system为robinson授予CREATETABLE、CREATESESSION权限

           Connected.

           SQL> GRANT CREATE TABLE,CREATE SESSION  TO robinson;

 

           Grant succeeded.

      

    c.使用系统权限

        --使用robinson具有创建会话、创建表

           SQL> CREATE TABLE tb1 AS SELECT * FROM USER_TABLES; --下面提示没有权限在users表空间创建对象

           CREATE TABLE tb1 AS SELECT * FROM USER_TABLES

                                         *

           ERRORatline1:

           ORA-01950:

 no privileges on tablespace 'USERS'

          

           SQL> CONNsys as sysdba;  --使用sys帐户登陆并为robinson在users表空间指定配额后可以创建表tb1

           Enterpassword:

           Connected.

           SQL> ALTER USER robinsonQUOTA10M ON USERS;

 

           User altered.

 

           SQL> CONNrobinson/lion;

           Connected.

           SQL> CREATE TABLE tb1 AS SELECT * FROM USER_TABLES;

 

           Table created.

   

    d.查看系统权限

        dba_sys_privs  --针对所有用户被授予的系统权限

        user_sys_privs --针对当前登陆用户被授予的系统权限

      

           SQL> SELECT grantee,privilege,admin_option FROM dba_sys_privs

             2  WHERE grantee IN ('SCOTT','ROBINSON')

             3  ORDER BY grantee;

 

           GRANTEE                        PRIVILEGE                                ADM

           -------------------------------------------------------------------------

           ROBINSON                       CREATE SESSION                           NO

           ROBINSON                       CREATE TABLE                             NO

           ROBINSON                       EXECUTE ANY PROCEDURE                    NO

           SCOTT                          CREATE PUBLIC SYNONYM                    NO

           SCOTT                          CREATE SESSION                           NO

           SCOTT                          CREATE SYNONYM                           NO

           SCOTT                          CREATE TABLE                             NO

           SCOTT                          CREATE USER                              NO

           SCOTT                          CREATE VIEW                              NO

           SCOTT                          EXECUTE ANY PROCEDURE                    YES

           SCOTT                          UNLIMITEDTABLESPACE                     NO

      

    e.回收系统权限

      REVOKE {privilege | role} FROM {user_name | role_name | PUBLIC}

           

           --下面的示例中并没有回收掉原来由scott授予给robisnonEXECUTEANYPROCEDURE 的权限

           SQL> REVOKE EXECUTE ANY PROCEDURE FROM scott;

 

           Revoke succeeded.

 

           SQL> select grantee,privilege,admin_option from dba_sys_privs

             2  where grantee in ('SCOTT','ROBINSON')  and privilege = 'EXECUTEANYPROCEDURE'

             3  order by grantee;

 

           GRANTEE                        PRIVILEGE                                ADM

           -------------------------------------------------------------------------

           ROBINSON                       EXECUTE ANY PROCEDURE                    NO

 

       注意:

对于使用withadminoption 为某个用户授予系统权限,那么对于被这个用户授予相同权限的所有用户来说,取消该用户的系统权限并不会级联取消这些用户的相同权限

3.2对象权限

       不同的对象具有不同的对象权限

       对象的拥有者拥有所有权限

       对象的拥有者可以向外分配权限

       ORACLE一共有种对象权限

 

       对象权限         表   视图   序列   过程

       修改(alter)         √            √

       删除(delete)        √    √

       执行(execute)                             √

       索引(index)         √

       插入(insert)        √    √

       关联(references)    √    √

       选择(select)        √    √      √

       更新(update)        √    √

 

    a.对象授权

       GRANT object_priv|ALL [(columns)]

       ON object

       TO {user|role|PUBLIC}

       [WITHGRANTOPTION];

 

       ALL:

所有对象权限

       PUBLIC:

授给所有的用户

       WITH GRANT OPTION:

允许用户再次给其它用户授权

   

    b.授予系统权限与授予对象权限的语法差异:

       授予对象权限时需要指定关键字ON,从而能够确定权限所应用的对象。

对于表和视图可以指定特定的列来授权。

      

    --对象授权示例

       SQL> SHOW USER;

       USER is "SCOTT"

       SQL> GRANT SELECT ON emp TO robinson;

 

       Grant succeeded.

      

       SQL> GRANT UPDATE(sal,mgr) ON emp TO robinson WITH GRANT OPTION;

 

       Grant succeeded.

   

    --新创建一个用户john,使用robinson账户授予更新scott.emp(sal,mgr)的权限

       SQL> CREATE USER johnIDENTIFIED BY john;

 

       User created.

 

       SQL> GRANT CREATE SESSION TO john;

 

       Grant succeeded.

      

       SQL> CONNROBINSON/LION

       Connected.

       SQL> GRANT UPDATE(sal,mgr) ON scott.emp TO john;   --授予scott.emp(sal,mgr)的更新权限

 

       Grant succeeded.

      

       SQL> UPDATE scott.emp SET sal = sal + 100 WHERE ename = 'SCOTT';  --成功更新

 

       1rowupdated.   

   

    --向数据库中所有用户分配权限

       SQL> GRANT SELECT ON dept TO PUBLIC;

 

        Grant succeeded.

 

    c.查询权限分配情况

    数据字典视图          描述

    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> SELECT * FROM user_tab_privs_made; --下面是scott用户开放的对象权限

   

       GRANTEE              TABLE_NAME               GRANTOR                   PRIVILEGE            GRAHIE

       -----------------------------------------------------------------------------------------------

       PUBLIC               DEPT                     SCOTT                     SELECT               NO  NO

       ROBINSON             EMP                      SCOTT                     SELECT               NO  NO  

      

    --查询列上开放的对象权限

       SQL> SELECT * FROM user_col_privs_made;

 

       GRANTEE              TABLE_NAME           COLUMN_NAME          GRANTOR        PRIVILEGE            GRA

       ---------

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 人文社科 > 法律资料

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2