首页 > 数据库 >oracle数据库用户

oracle数据库用户

时间:2022-09-26 12:23:21浏览次数:40  
标签:数据库 用户 sys sysdba 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权限的用户,如: 

normal 、sysdba、 sysoper这三种系统权限有什么区别?

  1. normal 是普通用户 
  2. sysdba 拥有最高的系统权限,登陆后是 sys,如我们使用sqlplus来连接数据库时,输入:sqlplus sys/**** as sysdba 。
  3. 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

标签:数据库,用户,sys,sysdba,oracle,权限
From: https://www.cnblogs.com/godzzz/p/16730128.html

相关文章

  • day02 --> (DQL、约束、多表之间的关系、范式、数据库的备份和还原)
    一、DQL:查询语句1.排序查询语法:orderby子句orderby排序字段1排序方式1,排序字段2排序方式2...排序方式:ASC:升序,默认DESC:降序注意:如果有多个排序条件,则当前......
  • 常见的数据库软件介绍和MySql的安装
    常见的数据库软件介绍MySQL:开源免费的数据库,小型的数据库,已经被Oracle收购了,MySQL6.x版本也开始收费Oracle:收费的大型数据库,Oracle公司的产品,Oracle收购SUN公司,收购MYSQL......
  • oracle数据库集群基础操作
    1.关闭数据库切换至oracle用户1.1查看数据库实例状态[oracle@db1~]$srvctlstatusdatabase-dorclInstanceorcl1isrunningonnodedb1Instanceorcl2isrun......
  • [Oracle] LeetCode 76 Minimum Window Substring 双指针
    Giventwostringssandtoflengthsmandnrespectively,returntheminimumwindowsubstringofssuchthateverycharacterint(includingduplicates)isin......
  • 创建数据库表
    在询问窗口中编写创建数据库的代码:注意事项:使用英文,表的名称和字段,尽量使用飘号 ‘’(此页面看不出来)括起来字符串使用单引号括起来所有的语句后面加,(英文的)最......
  • MySQL通过Data恢复数据库
    在真实的开发环境中,服务器突然蹦了,MySQL指令也不行了,备份...。只能通过物理备份Data。那我们如何通过Data恢复数据库。太简单了,只是复制粘贴的是。备份Data。备份Dat......
  • 数据库的字段属性
      unsigned 表示无符号整数,声明了该列不能声明为负数Zerofill:0填充的,不足的位数用0来填充   例如你设置的是长度为0的int类型,你只输入了1,那么系统会为你......
  • 银河麒麟操作系统root用户登录图形化界面
    第一步、为root用户设置密码sudopasswd设置root用户密码第二步、开启root登录权限vim/usr/share/lightdm/lightdm.conf.d/60-kylin.conf,加入greeter-show-manual-lo......
  • [Oracle] LeetCode 1636 Sort Array by Increasing Frequency 双map
    Givenanarrayofintegersnums,sortthearrayinincreasingorderbasedonthefrequencyofthevalues.Ifmultiplevalueshavethesamefrequency,sortthem......
  • 【笔记】Oracle union all&for update锁
    【笔记】Oracleunionall&forupdateunionall在Oracle中有三种类型的集合操作UNION:求并,重复记录只显示一次UNIONALL:求并集,显示所有记录信息INTERSECT:求交集MINUS......