Oracle grant all privileges to user

测试流程:

解锁HR用户:
SQL> alter user hr account unlock identified by hr;
User altered.

创建一个test用户
SYS@orcl11g> CREATE USER test IDENTIFIED BY test DEFAULT TABLESPACE users  	
此时test用户没有任何权限


在sys用户下建表t1
SQL> create table t1 as select * from dba_objects;
Table created.

授予HR查询sys.t1的对象权限
SQL> grant select on t1 to hr;
Grant succeeded.

SQL> conn hr/hr
Connected.

此时HR用户的对象权限
SQL>select * from user_tab_privs_recd;
OWNER      TABLE_NAME        GRANTOR             PRIVILEGE                                GRA HIE
------------------------------ ------------------------------ ------------------------------ -------------
SYS      DBMS_STATS                        SYS                            EXECUTE                                  NO  NO
SYS         T1                             SYS                            SELECT                                   NO  NO

此时HR用户的系统权限
SQL> select * from user_sys_privs;
USERNAME                       PRIVILEGE                                ADM
------------------------------ ---------------------------------------- ---
HR                             CREATE VIEW                              NO
HR                             UNLIMITED TABLESPACE                     NO
HR                             CREATE DATABASE LINK                     NO
HR                             CREATE SEQUENCE                          NO
HR                             CREATE SESSION                           NO
HR                             ALTER SESSION                            NO
HR                             CREATE SYNONYM                           NO

使用HR用户执行grant all privileges
SQL> grant all privileges to test;
grant all privileges to test
*
ERROR at line 1:
ORA-01031: insufficient privileges

授予HR DBA权限
SQL> grant dba to hr;
Grant succeeded.

此时HR的对象权限以及系统权限没有变化
SQL> select * from user_sys_privs;
USERNAME                       PRIVILEGE                                ADM
------------------------------ ---------------------------------------- ---
HR                             CREATE VIEW                              NO
HR                             UNLIMITED TABLESPACE                     NO
HR                             CREATE DATABASE LINK                     NO
HR                             CREATE SEQUENCE                          NO
HR                             CREATE SESSION                           NO
HR                             ALTER SESSION                            NO
HR                             CREATE SYNONYM                           NO

SQL>select * from user_tab_privs_recd;
OWNER      TABLE_NAME        GRANTOR             PRIVILEGE                                GRA HIE
------------------------------ ------------------------------ ------------------------------ -------------
SYS      DBMS_STATS                        SYS                            EXECUTE                                  NO  NO
SYS         T1                             SYS                            SELECT                                   NO  NO


执行grant all privileges
SQL> grant all privileges to test;
Grant succeeded.

SQL> conn test/test
Connected.

SQL> select * from user_tab_privs_recd;
no rows selected

SQL> select * from user_sys_privs;
USERNAME                       PRIVILEGE                                ADM
------------------------------ ---------------------------------------- ---
TEST                           DROP ANY MEASURE FOLDER                  NO
TEST                           ALTER ANY CUBE                           NO
...
...
TEST                           ALTER TABLESPACE                         NO
TEST                           AUDIT SYSTEM                             NO

200 rows selected.

SYS用户查询:
SQL> select count(*) from user_sys_privs;
  COUNT(*)
----------
       200

结论:
grant all privileges to B; 这个语句,普通用户是执行不了的,举例 如果想要普通用户A执行,A用户需要拥有DBA权限,A用户拥有DBA权限后执行 grant all privileges to B,B用户拥有的是SYS用户的全部系统权限,而不是A用户的系统权限 并且该语句只包含系统权限,不包含对象权限。

CREATE USER cedar IDENTIFIED BY cedar DEFAULT TABLESPACE CEDAR_DATA TEMPORARY TABLESPACE TEMP PROFILE DEFAULT ACCOUNT UNLOCK; -- 5 Roles for cedar GRANT DBA TO cedar; GRANT RESOURCE TO cedar WITH ADMIN OPTION; GRANT AQ_ADMINISTRATOR_ROLE TO cedar; GRANT CONNECT TO cedar WITH ADMIN OPTION; GRANT AQ_USER_ROLE TO cedar; ALTER USER cedar DEFAULT ROLE ALL; -- 44 System Privileges for cedar GRANT CREATE ANY DIRECTORY TO cedar WITH ADMIN OPTION; GRANT CREATE PUBLIC SYNONYM TO cedar WITH ADMIN OPTION; GRANT EXECUTE ANY CLASS TO cedar WITH ADMIN OPTION; GRANT DROP ANY VIEW TO cedar WITH ADMIN OPTION; GRANT CREATE CLUSTER TO cedar; GRANT ALTER SYSTEM TO cedar; GRANT UPDATE ANY TABLE TO cedar; GRANT INSERT ANY TABLE TO cedar; GRANT LOCK ANY TABLE TO cedar; GRANT CREATE EXTERNAL JOB TO cedar WITH ADMIN OPTION; GRANT EXECUTE ANY PROGRAM TO cedar WITH ADMIN OPTION; GRANT CREATE JOB TO cedar WITH ADMIN OPTION; GRANT DROP ANY DIRECTORY TO cedar WITH ADMIN OPTION; GRANT ALTER ANY TRIGGER TO cedar; GRANT CREATE DATABASE LINK TO cedar; GRANT DROP ANY TABLE TO cedar WITH ADMIN OPTION; GRANT CREATE TABLE TO cedar WITH ADMIN OPTION; GRANT QUERY REWRITE TO cedar; GRANT ANALYZE ANY TO cedar; GRANT DROP ANY TRIGGER TO cedar; GRANT EXECUTE ANY PROCEDURE TO cedar; GRANT SELECT ANY TABLE TO cedar WITH ADMIN OPTION; GRANT ALTER ANY TABLE TO cedar; GRANT UNLIMITED TABLESPACE TO cedar WITH ADMIN OPTION; GRANT CREATE SESSION TO cedar; GRANT CREATE ANY TRIGGER TO cedar; GRANT DROP ANY PROCEDURE TO cedar WITH ADMIN OPTION; GRANT ALTER ANY PROCEDURE TO cedar; GRANT DROP PUBLIC SYNONYM TO cedar WITH ADMIN OPTION; GRANT DROP ANY SYNONYM TO cedar WITH ADMIN OPTION; GRANT MANAGE SCHEDULER TO cedar WITH ADMIN OPTION; GRANT CREATE ANY PROCEDURE TO cedar; GRANT CREATE PROCEDURE TO cedar WITH ADMIN OPTION; GRANT CREATE SEQUENCE TO cedar; GRANT CREATE VIEW TO cedar WITH ADMIN OPTION; GRANT CREATE SYNONYM TO cedar; GRANT DROP ANY INDEX TO cedar; GRANT DELETE ANY TABLE TO cedar; GRANT CREATE ANY TABLE TO cedar; GRANT CREATE ANY JOB TO cedar WITH ADMIN OPTION; GRANT SELECT ANY DICTIONARY TO cedar WITH ADMIN OPTION; GRANT CREATE ROLE TO cedar; GRANT CREATE ANY SYNONYM TO cedar WITH ADMIN OPTION; GRANT ALTER SESSION TO cedar WITH ADMIN OPTION; GRANT EXECUTE ON sys.dbms_aq TO cedar; GRANT EXECUTE ON sys.dbms_aqadm TO cedar; GRANT EXECUTE ON sys.dbms_network_acl_admin TO cedar; GRANT ALL ON sys.DBMS_LOCK TO cedar; 这个SQL在oracle 能用吗
06-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值