本文共 1878 字,大约阅读时间需要 6 分钟。
关于sysdba,sysoper,dba这些名词在工作中可能接触的比较多,如果接触的环境是服务器端的,sysdba可能是经常用到的。如果是数据库的维护工作,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角色。#2 如果直接拿sys来登录,不使用sysdba,会有下面的错误。sqlplus sys/oracleORA-28009: connection as SYS should be as SYSDBA or SYSOPER#3 sysdba对应的用户时SYS,而sysoper对应的用户PUBLIC conn / as sysoperUSER is "PUBLIC" conn / as sysdbaUSER is "SYS"#4 如果在服务端登录,随便用一个用户。因为设置了操作系统级的验证,所以都可以使用sysdba.conn test/test as sysdbaORA-01031: insufficient privileges#5 关于sys,不得不提到密码文件。如果没有密码文件。会报如下的错误。
[ora11g@rac1 dbs]$ sqlplus sys/oracle@test01 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
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.
SQL> exit#6 关于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.
SQL> select count(*)from cat;
COUNT(*)4809
SQL> conn n1/n1
COUNT(*)406
转载地址:http://sxpsf.baihongyu.com/