oracle 11g 角色口令
oracle 11g 角色口令
oracle 11g 中測試 擁有口令的角色
SYS@ sms> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE 11.2.0.4.0 Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
1. 建立角色 role_01無密碼 role_02 有密碼
SYS@ sms> create role role_01;
Role created.
SYS@ sms> create role role_02 identified by oracle;
Role created.
SYS@ sms> grant connect,create table to role_01;
Grant succeeded.
SYS@ sms> grant connect ,create view to role_02;
SYS@ sms> create user zhou identified by zhou1234 quota unlimited on users;
User created.
SYS@ sms> grant role_01,role_02 to zhou;
Grant succeeded.
SYS@ sms> grant role_01,role_02 to zhou;
Grant succeeded.
SYS@ sms> conn zhou/zhou1234
Connected.
ZHOU@ sms> create table t(id number);
Table created.
ZHOU@ sms> insert into t values(1);
1 row created.
ZHOU@ sms> commit;
Commit complete.
2. 此時就出現問題了,role_02 明明有 create view 而且賦予給了 zhou 這裡就沒有呢?
ZHOU@ sms> create view view_1 as select * from t;
create view view_1 as select * from t
*
ERROR at line 1:
ORA-01031: insufficient privileges
3. 檢視 tyger_ro2 的default_role 為NO 難道 role_02 角色失效???
ZHOU@ sms> col USERNAME for a20
ZHOU@ sms> col GRANTED_ROLE for a20
ZHOU@ sms> select USERNAME,GRANTED_ROLE,DEFAULT_ROLE from user_role_privs;
USERNAME GRANTED_ROLE DEF
-------------------- -------------------- ---
ZHOU ROLE_01 YES
ZHOU ROLE_02 NO
4. 再檢視當前會話的許可權,果然沒有 create view 許可權
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE TABLE
5. 設定 tyger_ro2 許可權生效
ZHOU@ sms> set role role_02 identified by oracle;
Role set.
6. 當前使用者具有的許可權不變
ZHOU@ sms> select USERNAME,GRANTED_ROLE,DEFAULT_ROLE from user_role_privs;
USERNAME GRANTED_ROLE DEF
-------------------- -------------------- ---
ZHOU ROLE_01 YES
ZHOU ROLE_02 NO
7.當前會話用了 create view 許可權 卻沒有了create table 許可權
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE VIEW
ZHOU@ sms> create view view_1 as select * from t;
View created.
ZHOU@ sms> select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
T TABLE
VIEW_1 VIEW
8. 重新登入會話,許可權恢復原樣
ZHOU@ sms> conn zhou/zhou1234
Connected.
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE TABLE
總結:
在oracle 11g 中,帶有口令的角色賦予使用者,預設情況下是失效的,當 set role 生效後,其他角色所具有的許可權失效, 只在當前會話有效
reference :
oracle 11g 中測試 擁有口令的角色
SYS@ sms> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE 11.2.0.4.0 Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production
1. 建立角色 role_01無密碼 role_02 有密碼
SYS@ sms> create role role_01;
Role created.
SYS@ sms> create role role_02 identified by oracle;
Role created.
SYS@ sms> grant connect,create table to role_01;
Grant succeeded.
SYS@ sms> grant connect ,create view to role_02;
SYS@ sms> create user zhou identified by zhou1234 quota unlimited on users;
User created.
SYS@ sms> grant role_01,role_02 to zhou;
Grant succeeded.
SYS@ sms> grant role_01,role_02 to zhou;
Grant succeeded.
SYS@ sms> conn zhou/zhou1234
Connected.
ZHOU@ sms> create table t(id number);
Table created.
ZHOU@ sms> insert into t values(1);
1 row created.
ZHOU@ sms> commit;
Commit complete.
2. 此時就出現問題了,role_02 明明有 create view 而且賦予給了 zhou 這裡就沒有呢?
ZHOU@ sms> create view view_1 as select * from t;
create view view_1 as select * from t
*
ERROR at line 1:
ORA-01031: insufficient privileges
3. 檢視 tyger_ro2 的default_role 為NO 難道 role_02 角色失效???
ZHOU@ sms> col USERNAME for a20
ZHOU@ sms> col GRANTED_ROLE for a20
ZHOU@ sms> select USERNAME,GRANTED_ROLE,DEFAULT_ROLE from user_role_privs;
USERNAME GRANTED_ROLE DEF
-------------------- -------------------- ---
ZHOU ROLE_01 YES
ZHOU ROLE_02 NO
4. 再檢視當前會話的許可權,果然沒有 create view 許可權
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE TABLE
5. 設定 tyger_ro2 許可權生效
ZHOU@ sms> set role role_02 identified by oracle;
Role set.
6. 當前使用者具有的許可權不變
ZHOU@ sms> select USERNAME,GRANTED_ROLE,DEFAULT_ROLE from user_role_privs;
USERNAME GRANTED_ROLE DEF
-------------------- -------------------- ---
ZHOU ROLE_01 YES
ZHOU ROLE_02 NO
7.當前會話用了 create view 許可權 卻沒有了create table 許可權
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE VIEW
ZHOU@ sms> create view view_1 as select * from t;
View created.
ZHOU@ sms> select * from tab;
TNAME TABTYPE CLUSTERID
------------------------------ ------- ----------
T TABLE
VIEW_1 VIEW
8. 重新登入會話,許可權恢復原樣
ZHOU@ sms> conn zhou/zhou1234
Connected.
ZHOU@ sms> select * from session_privs;
PRIVILEGE
----------------------------------------
CREATE SESSION
CREATE TABLE
總結:
在oracle 11g 中,帶有口令的角色賦予使用者,預設情況下是失效的,當 set role 生效後,其他角色所具有的許可權失效, 只在當前會話有效
reference :
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/27036311/viewspace-1307902/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle DBA 角色重建Oracle
- oracle 4--角色Oracle
- Oracle之11g DataGuardOracle
- Oracle 11G 安裝文件Oracle
- benchmark 壓測Oracle 11gOracle
- sysbench壓測Oracle 11gOracle
- ORACLE DG之備庫角色Oracle
- [20180316]改變oracle使用者口令時限.txtOracle
- Oracle 11G 安裝 bbed 工具Oracle
- oracle 11g data guard維護Oracle
- oracle 11g OEM在哪裡找到???Oracle
- oracle 11g 常用命令Oracle
- Oracle 11g RAC Silent Install For NFSOracleNFS
- Oracle 11g刪除庫重建Oracle
- Oracle 11G 修改scan_ipOracle
- Oracle 11G RAC叢集安裝(3)——安裝OracleOracle
- Oracle Linux 6.7 靜預設安裝Oracle 11gOracleLinux
- 角色resource在11g和12c中的區別
- Oracle 11g RAC 監聽日常管理Oracle
- Oracle 11g 052題庫解析1Oracle
- oracle 11g datagurd主從切換Oracle
- ORACLE10G升級11GOracle
- Oracle 11g RAC手動新增serviceOracle
- Oracle 11g dg broker自動failoverOracleAI
- Automatic Diagnostic Repository (ADR) with Oracle Net for 11gOracle
- Oracle 11g關閉開啟AWROracle
- oracle 11g 系統審計功能Oracle
- Oracle:Redhat 7 + Oracle RAC 11g 安裝 bug 總結OracleRedhat
- oracle ERROR: ORA-28002: 7 天之後口令將過期OracleError
- Oracle dba角色和sysdba的區別Oracle
- Oracle 11g 重新建立控制檔案Oracle
- Oracle Data Pump 11G 資料泵元件Oracle元件
- Oracle 11g dataguard 配置簡約步驟Oracle
- oracle 11g自動記憶體管理Oracle記憶體
- Oracle 11g RAC重新新增節點Oracle
- Oracle 11g升級到12COracle
- Oracle GoldenGate 11g官方文件Administrator’s GuideOracleGoGUIIDE
- Oracle 11g DG新特性--Automatic block repairOracleBloCAI
- Oracle 11g單主搭建物理DGOracle