oracle控制用户权限命令
ORACLE控制用户权限:
首先使用系统中的拥有DBA权限的账号(system)登录;
一、创建用户:
1、DBA使用creater user语句创建用户:
--创建登录用户名为:user01,密码为:user01
create user user01 identified by user01;
此时登录会显示:
ORA-01045:user USER01 lacks CREATE SESSION privilege;logon denied;
--用户user01缺乏create session权限,拒绝登录;
2、然后我们使用grant命令给user01用户赋予create session权限,执行以下命令:
--赋予user01用户create session权限
grant create session to user01;
此时登录,登录成功,然后我们使用该用户创建一张表:
create table test_table(
id int,
name varchar2(10)
);
这时显示:ORA-01031:权限不足
然后我们给用户赋予创建表的权限
grant create table to user01;
此时显示:ORA-01950:对表空间 “USERS” 无权限;
注:接下来的命令需要使用拥有DBA权限的用户(system)
--给user01用户赋予表空间,unlimited(无限制),也可用具体的大小(10M)
alert user user01 quota unlimited on users;
此时再执行创建表语句即可成功;
然后执行查询语句:
select * from test_tbale;
此时查询表数据,执行成功(此时表中无数据)
3、修改用户的部分权限
此时在user01用户下修改user02用户的表空间:
--修改user02的表空间为无限制
alert user user02 quota unlimited on users;
此时显示:ORA-01301:权限不足(因为只有系统用户有权限修改)
但是自己想要修改自己的部分权限是可以的:
--修改user01用户的密码为user
alert user user01 identified by user;
这时是可以的。
二、创建角色并赋予权限
创建角色;
为角色赋予权限;
再将角色赋予用户;
1、创建角色
create role my_role;
2、为角色赋予权限:
--为角色my_role赋予登录,创建表,创建视图,创建存储过程等权限
grant create session,create table,create view,create procedure to my_role
3、将角色赋予用户:
--将角色my_role赋予了用户user02,user02也就拥有的my_role所拥有的权限
grant my_role to user02;
三、对象权限
不同的对象拥有不同的对象权限;
对象的拥有者拥有所有权限;
对象的拥有者可以向外分配权限;
| CREATE SESSION |
| CREATE TABLE |
| CREATE SEQUENCE |
| CREATE TABLE |
| CREATE VIEW |
1、将scott用户下的employees表的查询,修改权限赋予user01用户:
grant select,update on sott.employees to user01;
2、with grant option 和 public 关键字 -- 使用户同样拥有分配的权利
将scott用户的departments表的查询权限赋予user01用户:
grant select on scott.departments to user01 with grant option;
意思是:用户user01可以将赋给自己的scott用户的departments表的查询权限再赋予其他的用户
3、使用scott用户登录执行以下命令:
grant select,update on locations to public;
意思是:用户scott将自己的locations表的查询,修改权限赋予了所有用户;
四、收回对象权限
查询权限分配情况(select * from ...)
| 数据字典视图 | 描述 |
| ROLE_SYS_PRIVS | 角色拥有的系统权限 |
| ROLE_TAB_PRIVS | 角色拥有的对象权限 |
| USER_ROLE_PRIVS | 用户拥有的角色 |
| USER_TAB_PRIVS_MADE | 用户分配的关于表对象权限 |
| USER_TAB_PRIVS_RECD | 用户拥有的关于表对象权限 |
| USER_COL_PRIVS_MADE | 用户分配的关于列的对象权限 |
| USER_COL_PRIVS_RECD | 用户拥有的关于列的对象权限 |
| USER_SYS_PRIVS | 用户拥有的系统权限 |
1、收回用户user01关于employees表的查询权限:
revoke select on employees from user01;
总结:
DCL控制数据库权限
此时您已经可以熟练的对数据库权限进行相关操作了
| 语句 | 功能 |
| CREATE USER | 创建用户(通常由DBA完成) |
| GRANT | 分配权限 |
| CREATE ROLE | 创建角色(通常由DBA完成) |
| ALERT USER | 修改用户密码 |
| REVOKE | 收回权限 |
oracle控制用户权限命令的更多相关文章
- Oracle(控制用户权限)
权限允许用户访问属于其它用户的对象或执行程序, ORACLE系统提供权限:Object 对象级.System 系统级 查看权限的数据字典: 字典名 含义 ROLE_SYS_PRIVS System p ...
- 如何实现Oracle修改用户权限 .
这里将介绍Oracle修改用户权限的实现过程,包括一些权限管理方面的东西.希望通过本文能对大家了解Oracle修改用户权限有所帮助. ORACLE数据库用户与权限管理 ORACLE是多用户系统,它允许 ...
- 转 oracle 学习- 用户权限角色
创建和删除用户是Oracle用户管理中的常见操作,但这其中隐含了Oracle数据库系统的系统权限与对象权限方面的知识.掌握还Oracle用户的授权操作和原理,可以有效提升我们的工作效率. Oracle ...
- 详解Oracle创建用户权限全过程
本文将介绍的是通过创建一张表,进而实现Oracle创建用户权限的过程.以下这些代码主要也就是为实现Oracle创建用户权限而编写,希望能对大家有所帮助. 注意:每条语语分开执行,结尾必须用分号; // ...
- oracle_控制用户权限
oracle_控制用户权限 ①对 限制 数据库安全: 系统安全 数据安全性 系统权限: 对于数据库的权限 对象权限: 操作数据库对象的权限 1.系统权限 ...
- Oracle查询用户权限
Oracle查询用户权限 -- 确定角色的权限select * from role_tab_privs ; 包含了授予角色的对象权限select * from role_ro ...
- Navicat连接Oracle数据库用户权限问题
解决Navicat连接Oracle数据库用户权限问题: 第一步:在cmd窗口运行[sqlplus], 第二步:输入Oracle的用户名和口令连接Oracle数据库, 第三步:执行授权代码,给用户授予D ...
- Oracle 学习笔记 13 -- 控制用户权限
数据库控制语言的功能室控制用户对数据库的存取权限. 用户对某类数据具有何种操作权限是有DBA决定的.Oracle 通过GRANT语句完毕权限的授予,通过REVOKE语句完毕对权限的收回. 权限分为系统 ...
- Oracle的用户权限和角色
用户和权限 LOCK|UNLOCK创建用户时是否锁定,默认为锁定状态.锁定的用户无法正常的登录进行数据库操作. --给普通用户SCOTT解锁,同时把SCOTT用户的密码进行修改 --语法结构:ALTE ...
随机推荐
- 【.NET 与树莓派】TM1638 模块的按键扫描
上一篇水文中,老周马马虎虎地介绍 TM1638 的数码管驱动,这个模块除了驱动 LED 数码管,还有一个功能:按键扫描.记得前面的水文中老周写过一个 16 个按键的模块.那个是我们自己写代码去完成键扫 ...
- 解决Git操作报错
情况一: 当我拉取的代码是最新的时候,git pull是可以正常的拉取的,但是却不可以提交,报错如下图: 情况二: 如果我目前不是最新的版本,需要git pull,此时拉取就会失败,报错如下图: 出现 ...
- kubelet分析-csi driver注册源码分析
kubelet注册csi driver分析 kubelet注册csi driver的相关功能代码与kubelet的pluginManager有关,所以接下来对pluginManager进行分析.分析将 ...
- .net core AES加密解密及RSA 签名验签
引用 using Org.BouncyCastle.Crypto.Parameters; using Org.BouncyCastle.Security; using System; using Sy ...
- Nginx-多服务绑定80端口及映射域名
多服务绑定80端口及映射域名 说明:业务需要配置的样例模板,如需深入了解,请查看官方文档 1.Nginx配置文件nginx.conf(可拆分多台机器部署) worker_processes 1; e ...
- Tars | Win10下Docker部署TarsJava(SpringBoot)全过程及踩坑记录
@ 目录 前言 1. 相关环境版本: 坑点一:VMware与Win10 Docker冲突 坑点二:20.版本TarsJava(SpringBoot)依赖文件缺失 2. Docker安装: 坑点三:Do ...
- 我通过调试ConcurrentLinkedQueue发现一个IDEA的小虫子(bug), vscode复现, eclipse毫无问题
前言: 本渣渣想分析分析Doug Lea大佬对高并发代码编写思路, 于是找到了我们今天的小主角ConcurrentLinkedQueue进行鞭打, 说实话草稿我都打好了, 就差临门一脚, 给踢折了 直 ...
- Nginx:Nginx日志切割方法
Nginx的日志文件是没有切割(rotate)功能的,但是我们可以写一个脚本来自动切割日志文件. 首先我们要注意两点: 1.切割的日志文件是不重名的,所以需要我们自定义名称,一般就是时间日期做文件名. ...
- XCTF Guess-the-Number
一.发现是jar文件,一定想到反汇编gdui这个工具,而且运行不起来,可能是我电脑问题,我就直接反编译出来了. 也发现了flag,和对应的算法,直接拉出来,在本地运行,后得到flag 二.java代码
- Hive源码上手及问题解决
一.编译准备 1.下载源码包 https://github.com/apache/hive/archive/refs/tags/rel/release-2.3.7.zip 或使用git直接拉取 无法解 ...