oracle的sys和system用户有啥区别


1 ) 最重要的区别,存储的数据的重要性不同

【 sys 】 所有 oracle 的数据字典的基表和视图都存放在 sys 用户中,这些基表和视图对于 oracle 的运行是至关重要的,由自己维护,任何用户都不能手动更改。 sys 用户拥有 dba , sysdba , sysoper 等角色或权限,是 oracle 权限最高的用户。

【 system 】 用户用于存放次一级的内部数据,如 oracle 的一些特性或工具的管理信息。 system 用户拥有普通 dba 角色权限。

2) 其次的区别,权限的不同。

【 system 】用户只能用 normal 身份登陆 em ,除非你对它授予了 sysdba 的系统权限或者 syspoer 系统权限。
【 sys 】用户具有 “SYSDBA” 或者 “SYSOPER” 系统权限,登陆 em 也只能用这两个身份,不能用 normal 。

 以 sys 用户登陆 Oracle ,执行 select * from V_$PWFILE_USERS; 可查询到具有 sysdba 权限的用户,如:

> select * from V_$PWFILE_USERS;
   USERNAME SYSDBA SYSOPER
   SYS TRUE TRUE

Sysdba 和 sysoper 两个系统权限区别

normal 、 sysdba 、 sysoper 有什么区别
normal 是普通用户
另外两个,你考察他们所具有的权限就知道了
sysdba 拥有最高的系统权限,登陆后是 sys
sysoper 主要用来启动、关闭, sysoper 登陆后用户是 public

sysdba 和 sysoper 属于 system privilege ,也称为 administrative privilege ,拥有例如开启关闭之类一些系统管理级别的权限 sysdba 和 sysoper 具体的权限可以看下表:

系统权限 sysdba sysoper
区别 Startup( 启动 ) startup
Shutdown( 关闭数据库 ) shutdown
alter database open/mount/backup alter database open/mount/backup
改变字符集 none
create database( 创建数据库 ) None 不能创建数据库
drop database( 删除数据库 ) none
create spfile create spfile
alter database archivelog( 归档日志 ) alter database archivelog
alter database recover( 恢复数据库 ) 只能完全恢复,不能执行不完全恢复
拥有restricted session( 会话限制 ) 权限 拥有restricted session 权限
可以让用户作为sys 用户连接 可以进行一些基本的操作,但不能查看用户数据
登录之后用户是sys 登录之后用户是public

system 如果正常登录,它其实就是一个普通的 dba 用户,但是如果以 as sysdba 登录,其结果实际上它是作为 sys 用户登录的,这一点类似 里面的 sudo 的感觉,从登录信息里面我们可以看出来。因此在 as sysdba 连接数据库后,创建的对象实际上都是生成在 sys 中的。其他用户也是一样,如果 as sysdba 登录,也是作为 sys 用户登录的,看以下实验:
> create user strong identified by strong;

用户已创建。

> conn strong/strong@magick as sysdba;

已连接。

> show user;

USER 为 “SYS”

> create table test(a int);

表已创建。

SQL> select owner from dba_tables where table_name='test';

未选定行 // 因为创建表时 oracle 自动转为大写,所以用小写查的时候是不存在的;

SQL> select owner from dba_tables where table_name='TEST';

OWNER

——————————

SYS

dba 和 sysdba 的区别
dba 、 sysdba 这两个系统角色什么区别呢
在说明这一点之前我需要说一下 oracle 服务的创建过程
· 创建实例→ · 启动实例→ · 创建数据库 (system 表空间是必须的 )
启动过程
· 实例启动→ · 装载数据库→ · 打开数据库

sysdba ,是管理 oracle 实例的,它的存在不依赖于整个数据库完全启动,只要实例启动了,他就已经存在,以 sysdba 身份登陆,装载数据库、打开数据库。只有数据库打开了,或者说整个数据库完全启动后, dba 角色才有了存在的基础!

声明: 除非转自他站(如有侵权,请联系处理)外,本文采用 BY-NC-SA 协议进行授权 | 智乐兔
转载请注明:转自《oracle的sys和system用户有啥区别
本文地址:https://www.zhiletu.com/archives-461.html
关注公众号:智乐兔

赞赏

wechat pay微信赞赏alipay pay支付宝赞赏

上一篇
下一篇

相关文章

在线留言

你必须 登录后 才能留言!

在线客服
在线客服 X

售前: 点击这里给我发消息
售后: 点击这里给我发消息

智乐兔官微