Oracle 用户和权限
Oracle
中,一般不会轻易在一个服务器上创建多个数据库,在一个数据库中,不同的项
目由不同的用户访问,每一个用户拥有自身创建的数据库对象,因此用户的概念在
Oracle
中非常重要。Oracle 的用户可以用 CREATE USER 命令来创建。其语法是:
语法结构:创建用户
CREATE
USER 用户名 IDENTIFIED BY 口令 [ACCOUNT LOCK|UNLOCK]
语法解析:
LOCK|UNLOCK
创建用户时是否锁定,默认为锁定状态。锁定的用户无法正常的登录进
行数据库操作。
代码演示:创建用户
SQL> CREATE USER
jerry
2 IDENTIFIED BY tom
3 ACCOUNT UNLOCK;
Oracle 在 SQL*Plus
中的命令以分号(;)结尾,代表命令完毕并执行,系统同时会把
该命令保存在缓存中,缓存中只保存最近执行过的命令,如果重新执行缓存中的命
令,直接使用左斜杠符号(/)。如果命令不以分号结尾,该命令只是写入缓存保存起
来,但并不执行。
尽管用户成功创建,但是还不能正常的登录
Oracle 数据库系统,因为该用户还没有任
何权限。如果用户能够正常登录,至少需要 CREATE SESSION 系统权限。
Oracle
用户对数据库管理或对象操作的权利,分为系统权限和数据库对象权限。系统权
限比如:CREATE SESSION,CREATE TABLE
等,拥有系统权限的用户,允许拥有相应的系统操
作。数据库对象权限,比如对表中的数据进行增删改操作等,拥有数据库对象权限的用户可
以对所拥有的对象进行对应的操作。
还有一个概念就是数据库角色(role),数据库角色就是若干个系统权限的集合。下面
介绍几个常用角色:
?
CONNECT 角色,主要应用在临时用户,特别是那些不需要建表的用户,通常只赋予
他们 CONNECT role。CONNECT 是使用 Oracle
的简单权限,拥有 CONNECT 角色的用
户,可以与服务器建立连接会话(session,客户端对服务器连接,称为会话) 。
? RESOURCE
角色,更可靠和正式的数据库用户可以授予 RESOURCE
role。RESOURCE
提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器
(trigger)、索引(index)等。
?
DBA 角色, DBA role 拥有所有的系统权限----包括无限制的空间限额和给其他用户授
予各种权限的能力。用户 SYSTEM 拥有 DBA
角色。
一般情况下,一个普通的用户(如 SCOTT),拥有 CONNECT 和 RESOURCE
两个角色即可
进行常规的数据库开发工作。
可以把某个权限授予某个角色,可以把权限、角色授予某个用户。系统权限只能由
DBA
用户授权,对象权限由拥有该对象的用户授权,授权语法是:
语法结构:授权
GRANT角色|权限 TO
用户(角色)
代码演示:授权
SQL> GRANT CONNECT TO jerry;
授权成功。
SQL> GRANT
RESOURCE TO jerry;
授权成功。
SQL>
语法结构:其他操作
//回收权限
REVOKE 角色|权限
FROM 用户(角色)
//修改用户的密码
ALTER USER 用户名 IDENTIFIED BY
新密码
//修改用户处于锁定(非锁定)状态
ALTER USER 用户名 ACCOUNT LOCK|UNLOCK
相关文章
- 12-26jeecg中获取用户拥有的角色的数据权限
- 12-26TZ_10_spring-sucrity 服务器和页面的权限控制
- 12-26使用 ACL 来为用户赋予目录的读写权限
- 12-26ClichHouse-003-用户权限样例
- 12-26金融现金贷用户数据分析和用户画像(基于12万真实数据)
- 12-26DJANGO:从当前用户的所属用户组里查找其所拥有的权限矩阵
- 12-26【Teradata DSQL】获取env中的用户和口令到变量中(无需落地到文件中)
- 12-265G系列协议--3GPP--Release 16--TS 38.101-1--NR:用户设备(UE)无线电发射和接收--独立组网-1
- 12-26阶段5 3.微服务项目【学成在线】_day18 用户授权_06-方法授权-方法授权测试-无权限异常处理
- 12-26用户和用户组管理