一、系统用户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权限的用户,如:
normal 、sysdba、 sysoper这三种系统权限有什么区别?
- normal 是普通用户
- sysdba 拥有最高的系统权限,登陆后是 sys,如我们使用sqlplus来连接数据库时,输入:sqlplus sys/**** as sysdba 。
- sysoper 主要用来启动、关闭数据库,sysoper 登陆后用户是 public,sqlplus sys/oracle as sysoper
3、系统角色的不同
dba、sysdba这两个系统角色有什么区别呢?在说明这一点之前我需要说一下oracle服务
创建过程:创建实例→启动实例→创建数据库
启动过程:实例启动→装载数据库→打开数据库
sysdba,是管理oracle实例的,它的存在不依赖于整个数据库完全启动,只要实例启动了,他就已经存在,以sysdba身份登陆,装载数据库、打开数据库。只有数据库打开了,或者说整个数据库完全启动后,dba角色才有了存在的基础!二、oracle怎么增加用户
1、创建数据库用户
登录到system用户以创建其他用户,因为system具有创建别的用户的 权限。 在安装oracle时,用户或系统管理员首先可以为自己建立一个用户。
语法[创建用户]:create user 用户名 identified by 口令;
2、删除用户
语法:drop user 用户名;
若用户拥有对象,则不能直接删除,否则将返回一个错误值。指定关键字cascade,可删除用户所有的对象,然后再删除用户。
语法:drop user 用户名 cascade;
3、授权角色
(1)讲解三种标准角色
oracle为兼容以前版本,提供三种标准角色(role):connect、resource和dba,
- connect role(连接角色)
临时用户,特指不需要建表的用户,通常只赋予他们connect role。
connect是使用oracle简单权限,这种权限只对其他用户的表有访问权限,包括select/insert/update和delete等。
拥有connect role 的用户还能够创建表、视图、序列(sequence)、簇(cluster)、同义词(synonym)、回话(session)和其他 数据的链(link)。
- resource role(资源角色)
更可靠和正式的数据库用户可以授予resource role。
resource提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器(trigger)、索引(index)和簇(cluster)。
- dba role(数据库管理员角色)
dba role拥有所有的系统权限。
包括无限制的空间限额和给其他用户授予各种权限的能力。dba 由 system 用户拥有。
(2)授权命令
语法: grant connect, resource to 用户名;
(3)撤销权限
语法:revoke connect, resource from 用户名;
三、怎么查询oracle数据库字符集
查询字符集的方法:
1、用select * from nls_database_parameters
语句,可查询服务器字符集;
2、用select * from nls_instance_parameters
语句,可查询客户端字符集。
比较直观的查询方法:select userenv('language') from dual;
查询结果如:SIMPLIFIED CHINESE_CHINA.AL32UTF8