關於sysdba,sysoper,dba的區別
在oracle的官方文件中給出了sysdba和sysoper的區別。我在這個基礎上又加入了一些東西做點補充。
標黃的部分是sysdba和sysoper的不同之處。這兩個特殊的系統許可權和dba許可權還是有著明顯的差別。
System Privilege | Operations Authorized |
---|---|
SYSDBA |
Effectively, this system privilege allows a user to connect as user SYS. |
SYSOPER |
|
#1 sys,system使用者都是資料庫建立時內建的使用者。sys繫結的是sysdba系統許可權,system繫結的是dba角色。
sys的預設密碼是CHANGE_ON_INSTALL,而system的預設密碼是MANAGER
#2 如果直接拿sys來登入,不使用sysdba,會有下面的錯誤。
[ora11g@rac1 ~]$ sqlplus sys/oracle
SQL*Plus: Release 11.2.0.3.0 Production on Sat Nov 22 04:39:21 2014
Copyright (c) 1982, 2011, Oracle. All rights reserved.
ERROR:
ORA-28009: connection as SYS should be as SYSDBA or SYSOPER
#3 sysdba對應的使用者時SYS,而sysoper對應的使用者PUBLIC
SQL> conn / as sysoper
Connected.
SQL> show user
USER is "PUBLIC"
SQL> conn / as sysdba
Connected.
SQL> show user
USER is "SYS"
#4 如果在服務端登入,隨便用一個使用者。因為設定了作業系統級的驗證,所以都可以使用sysdba.
SQL> conn test/test as sysdba
Connected.
如果使用了tns連線的情況下。就會校驗test的許可權。發現不具備sysdba的系統許可權。
SQL> conn as sysdba
ERROR:
ORA-01031: insufficient privileges
#5 關於sys,不得不提到密碼檔案。如果沒有密碼檔案。會報如下的錯誤。
[ora11g@rac1 dbs]$ sqlplus as sysdba
SQL*Plus: Release 11.2.0.3.0 Production on Sat Nov 22 05:40:03 2014
Copyright (c) 1982, 2011, Oracle. All rights reserved.
ERROR:
ORA-01031: insufficient privileges
建立了密碼檔案之後,就沒有問題
[ora11g@rac1 dbs]$ orapwd password=oracle file=orapwTEST01 entries=2
[ora11g@rac1 dbs]$ sqlplus as sysdba
SQL*Plus: Release 11.2.0.3.0 Production on Sat Nov 22 05:40:37 2014
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL> exit
#6 關於sysdba和dba的區別,可以透過如下的例子來簡單示範一下。
使用者n1是dba使用者。我們使用sysdba和dba許可權的時候來看一下不同之處。
[ora11g@rac1 dbs]$ sqlplus n1/n1 as sysdba
SQL*Plus: Release 11.2.0.3.0 Production on Sat Nov 22 05:56:40 2014
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL> select count(*)from cat;
COUNT(*)
----------
4809
SQL> conn n1/n1
Connected.
SQL> select count(*)from cat;
COUNT(*)
----------
406
#7 sysdba具有的許可權要遠大於dba。我們平常使用的dba角色主要包括建立表,檢視,索引等等的明細許可權,但是sysdba可以做資料庫級的任何操作。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30496894/viewspace-2024775/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- sysdba,dba,sysoper的區別
- DBA,SYSDBA,SYSOPER三者的區別
- SYS,SYSTEM,DBA,SYSDBA,SYSOPER的區別與聯絡
- sysdba,sysoper,normal的區別ORM
- normal 、sysdba、 sysoper的區別ORM
- system sys,sysoper sysdba 的區別
- normal、sysdba、sysoper登陸oracle的區別理解ORMOracle
- dba和sysdba的區別
- sysdba和dba的區別
- 【Privilege】SYSOPER和SYSDBA特權的區別與聯絡
- Oracle dba角色和sysdba的區別Oracle
- 2 Day DBA-管理Oracle例項-關於管理帳戶和許可權-SYSDBA和SYSOPER系統許可權Oracle
- SYSDBA and SYSOPER Privileges in Oracle [ID 50507.1]Oracle
- 31、ASM的使用者SYSDBA和SYSOPERASM
- 總結sysdba和sysoper許可權
- dba和sysdba的區別(轉自“三十而立專欄”部落格)
- sysdba與sysoper系統特權介紹
- 11g文件學習----sysdba sysoper OSDBA OSOPER
- Oracle - ORA-28009: connection as SYS should be as SYSDBA OR SYSOPEROracle
- Oracle DBA 和Oracle EBS DBA 的最大區別Oracle
- 關於HashMap和Hashtable的區別HashMap
- 關於CI,ASCS,DI的區別
- dba_segments/dba_extents/dba_tables區別
- nginx關於root與alias的區別Nginx
- 關於C與C++的區別C++
- 關於 in與exist , not in與not exist 的區別
- 關於JSF與Struts的區別JS
- 關於gcc、make和CMake的區別GC
- 關於DBA工具的選擇
- dba_tables 和 dba_segments 表中 blocks 的區別BloC
- 關於stable_sort()和sort()的區別:
- 關於java的引用和c++的區別JavaC++
- 關於HashSet與TreeSet的區別與聯絡
- 關於String與StringBuffer的區別
- 關於重定向符>>與>的區別與作用
- 關於rman裡面的from 與until的區別
- dba_data_files和v$datafile的區別
- 關於MySQL與SQLLite的GroupBy排序原理的區別MySql排序