2、oracle用户和权限
权限主要可以分成三类:系统权限、角色、对象权限,角色是一类系统权限的分组,
Oracle 的角色存放在表 dba_roles 中,某角色包含的系统权限存放在 dba_sys_privs 中,
包含的对象权限存放在 dba_tab_privs 中。
2.1、系统权限:
系统权限其实就是用户在当前用户架构下所具有的权限,在11g中系统权限有200个,
比如create table,UNLIMITED TABLESPACE等。
1、查询当前用户拥有的系统权限:
select * from session_privs;
2、查询某一个用户的系统权限:
select * from dba_role_privs where GRANTEE='<用户名>';
select * from dba_sys_privs where GRANTEE='<用户名>';
2.2、角色:
角色其实就是一类系统权限的分组,所以给用户分配角色其实也是在给用户分配系统权限;
1、在oracle中有三个比较常用的角色:
1)
CONNECT(基本的连接), RESOURCE(程序开发),DBA(数据库管理);
2)
DBA:拥有全部特权,是系统最高权限,只有DBA才可以创建数据库结构;
RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构;
CONNECT:拥有Connect权限的用户只可以登录Oracle,不可以创建实体,不可以创建数据库结构;
3)
对于普通用户:授予connect, resource权限;
对于DBA管理用户:授予connect,resource, dba权限;
4)查看RESOURCE和CONNECT角色中所包含的系统权限:
SELECT * FROM dba_sys_privs WHERE grantee IN ('RESOURCE', 'CONNECT') ORDER BY 1;
2、查询当前用户拥有的角色:
SELECT * FROM USER_ROLE_PRIVS;
3、查询当前用户拥有的角色和对应的系统权限:
select * from role_sys_privs;
2.3、对象权限(表级权限):
对象权限指的是其它拥有用户的对象的权限,即对表的操作权限,其它用户对象的权限包括:
SELECT,DELETE,UPDATE,ALTER,INSERT,INDEX,REFERENCES,FLASHBACK,DEBUG,QUERY REWRITE,ON COMMIT REFRESH;
1、查询当前用户拥有的对象权限:
SELECT * FROM USER_TAB_PRIVS;
2.4、grant授权:
1、授予用户系统权限:
GRANT CREATE VIEW TO <用户名>;
#给用户添加"RESOURCE"角色权限中没有的创建视图的权限;
补充:
#CREATE DATABASE LINK:建立表空间链接
#CREATE SYNONYM:建立同义词
2、授予用户角色权限:
GRANT CONNECT,RESOURCE TO <用户名>;
3、授予用户对象权限:
GRANT SELECT,INSERT,UPDATE,DELETE ON <表名> TO <用户名>;
GRANT ALL PRIVILEGES ON <表名> to <用户名>;
grant connect,select any table to <用户名>;
#所有表赋予查询权限
2.5、REVOKE 回收权限:
1、回收系统权限:
REVOKE CREATE VIEW FROM <用户名>;
2、回收角色权限:
REVOKE CONNECT,RESOURCE FROM <用户名>;
3、回收对象权限:
REVOKE INSERT,UPDATE,DELETE ON <表名> FROM <用户名>;
2.5、角色管理:
1、创建一个角色:
create role <角色名>;
2、将系统权限授权给角色:
grant create any table,create procedure to <角色名>;
3、查看角色所包含的权限
SELECT * FROM dba_sys_privs WHERE grantee IN ('<角色名>') ORDER BY 1;
4、将角色授权给用户:
grant <角色名> to <用户名>;
alter user <用户名> default role <角色名>;
#将指定角色设置为指定用户的默认角色;
5、生效角色:
set role <角色名>;
#使特定的角色生效;
set role all;
#将所有的角色生效;
set role none;
#将所有的角色失效;
6、删除角色:
drop role <角色名>;
#角色删除后,原来拥用该角色的用户就不再拥有该角色了,相应的权限也就没有了;
2.6、用户操作:
1、创建用户:
create user <用户名> identified by <密码>;
alter user <用户名> identified by <密码>;
#修改密码;
2、删除用户:
drop user <用户名> cascade;
3、设置用户密码登录后失效,并要求修改密码:
alter user <用户名> password expire;
4、账户锁定和解锁:
alter user 用户名 account lock;
#账户锁定;
alter user 用户名 account unlock;
#解锁账号;
5、启用scott用户:
scott是一个系统已经新建好的普通用户,用户名scott,密码默认tiger,
默认状态是被锁定,DBA用户执行"alter user scott account unlock"可以
解锁登陆;
2、oracle用户和权限的更多相关文章
- Oracle用户,权限,角色以及登录管理 scoot 授权
Oracle用户,权限,角色以及登录管理 1. sys和system用户的区别 system用户只能用normal身份登陆em.除非你对它授予了sysdba的系统权限或者syspoer系统权限. sy ...
- Oracle 用户和权限
Oracle 用户和权限Oracle 中,一般不会轻易在一个服务器上创建多个数据库,在一个数据库中,不同的项目由不同的用户访问,每一个用户拥有自身创建的数据库对象,因此用户的概念在 Oracle中非常 ...
- Oracle用户、权限、角色管理学习(文字很系统)
Oracle用户.权限.角色管理 2009-03-16 13:20:50 标签:oracle 数据库 休闲 职场 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明 ...
- Oracle 用户管理权限
Oracle 用户管理权限 一.创建用户的Profile文件 SQL> create profile student limit // student为资源文件名 FAILED_LOGIN_AT ...
- Oracle用户、权限、角色管理(转)
http://blog.csdn.net/junmail/article/details/4381287 Oracle 权限设置一.权限分类:系统权限:系统规定用户使用数据库的权限.(系统权限是对用户 ...
- Oracle用户、权限、角色管理
Oracle 权限设置一.权限分类:系统权限:系统规定用户使用数据库的权限.(系统权限是对用户而言). 实体权限:某种权限用户对其它用户的表或视图的存取权限.(是针对表或视图而言的). 二.系统权 ...
- oracle用户、权限操作
oracle用户操作,权限操作: 1.创建用户,并让用户默认表空间为tb1: create user 用户名 identified by 密码 default namespace tb1 2.授权: ...
- oracle用户和权限
在oracle中,一个服务器上一般只有一个数据库.在一个数据库中,不同的用户项目由不同的用户访问,每一个用户拥有自身创建的数据库对象,当一个用户想访问其它用户下的数据库对象时,必须由对方授予一定的权限 ...
- oracle 用户系统权限
conn sys as sysdba; create user test identified by test; grant create session to test; grant create ...
随机推荐
- sosreport -a --report
sosreport -a --report 时间:2019-09-28 本文章向大家介绍sosreport -a --report,主要包括sosreport -a --report使用实例.应用技巧 ...
- Linux_搭建Samba服务(认证访问)
[RHEL8]-SMBserver:[RHEL7]-SMBclient !!!测试环境我们首关闭防火墙和selinux(SMBserver和SMBclient都需要) [root@localhost ...
- MyBatis 各种参数传递方式
MyBatis参数传递方式 情况一:Mapper映射器接口方法参数只有一个且为基本类型 接口方法: public List<UserEntity> selectUserByAge(int ...
- Lua _G
1.全局变量的原形 在Lua中,要声明全局变量很简单,那就是定义变量的时候,前面不要加上local. 这个神秘的全局变量,其实本质上也是一个table,它把我们创建的全局变量都保存到一个table里了 ...
- Linux(CentOS7)下二进制安装MySQL5.7.26
记录一下自己在 CentOS7 下二进制安装 MySQL5.7.26 的过程,之前使用 Linux(CentOS7)下rpm安装MySQL8.0.16 之后发现 rpm 方式安装不利于维护,也不利于单 ...
- Jenkins代码自动部署相关文档
环境 centos 7.0+ Java JDK 1.8+ jenkins 2.220 maven 3.0+ git 1.8+ 注意事项 一. linux 安装 JDK (jdk-8u201-linux ...
- Jupyter Notebook出现kernel error情况
今天重新装了anaconda,在运行时发现真快,可是在运行selenium的代码时候,发现自己按照以前写得帖子得步骤做,同样还是出现了错误,心里不免大吃一惊,难道我的做法是错的?等到发现有个 ker ...
- Java处理Excel中的日期格式
Java处理Excel中的日期格式 2011-12-23 17:34:03| 分类: java |举报 |字号 订阅 下载LOFTER 我的照片书 | 在Excel中的日期格式,其数值为距离1 ...
- Linux基础服务——Bind DNS服务 Part1
Linux基础服务--Bind DNS服务 Part1 DNS正向解析 实验环境: CentOS8.3.2011 IP地址:192.168.100.50 VMware虚拟环境 NAT网段 需要解析的区 ...
- 学妹问,学网站开发还是打 ACM?
聊聊我的选择 大家好,我是鱼皮,前几天看到一位大一计科同学的问题:我想学做 Web 项目,又想学算法搞 ACM,如何取舍呢 ? ACM 是国际大学生程序设计竞赛,旨在展示大学生创新能力.团队精神.编写 ...