Oracle442个应用场景-----------角色管理
--------------------------------角色管理------------------------------------
一、角色的概念和特性
1.什么是角色?
角色就是相关权限的命令集合。使用角色的主要目的就是为了简化权限的管理。
2.角色的特性有哪些?
a.使用grant和revoke赋予和回收系统权限
b.角色能够赋予给不论什么除自身之外的角色和用户
c.角色能够由系统和对象权限组成
d.能够启用和禁用角色
e.能够指定一个password
f.角色不被不论什么用户拥有,不在不论什么方案内
g.角色在数据字典中有各自的描写叙述
二、提前定义角色
提前定义角色是指Oracle所提供的角色,每种角色都用于运行一些特定的管理任务,以下我们介绍经常使用的提前定义角色connect,resource,dba。
1、connect角色
connect角色具有一般应用开发者须要的大部分权限。当建立了一个用户后,多数情况下,仅仅要给用户授予connect和resource角色就够了。
那么connect角色具有下面系统权限:
alter session
create cluster
create database link
create session
create view
create sequence
2、resource角色
resource角色具有应用开发者所须要的其它权限,比方建立存储过程、触发器等。这里须要注意的是resource角色隐含了unlimited tablespace系统权限。
resource角色包括下面系统权限:
create cluster
create indextype
create table
create sequence
create type
create procedure
create trigger
3、dba角色
dba角色具有全部的系统权限。及with admin option选项,默认的dba用户为sys和system他们能够将不论什么系统权限授予其它用户。
可是要注意的是dba角色不具备sysdba和sysoper的特权(启动和关闭数据库)。
Oracle 权限设置
一、权限分类:
系统权限:系统规定用户使用数据库的权限。(系统权限是对用户而言)。
实体权限:某种权限用户对其他用户的表或视图的存取权限。(是针对表或视图而言的)。
二、系统权限管理:
1、系统权限分类:
DBA: 拥有所有特权,是系统最高权限,仅仅有DBA才干够创建数据库结构。
RESOURCE:拥有Resource权限的用户仅仅能够创建实体,不能够创建数据库结构。
CONNECT:拥有Connect权限的用户仅仅能够登录Oracle。不能够创建实体,不能够创建数据库结构。
对于普通用户:授予connect, resource权限。
对于DBA管理用户:授予connect,resource, dba权限。
2、系统权限授权命令:
[系统权限仅仅能由DBA用户授出:sys, system(最開始仅仅能是这两个用户)]
授权命令:SQL> grant connect, resource, dba to username1 [,username2]...;
[普通用户通过授权能够具有与system同样的用户权限。但永远不能达到与sys用户同样的权限。system用户的权限也能够被回收。]
-------------------------------------------------------------------------------
应用场景36:在Enterprise Manager中查看用户信息
应用场景37:使用DBA_USERS视图查看用户信息
SELECT USERNAME,PASSWORD,LOCK_DATE,EXPIRY_DATE,PROFILE,ACCOUNT_STATUS,CREATED FROM DBA_USERS;
应用场景38:在Enterprise Manager中创建用户
应用场景39:
创建新用户:
create user hrman identified by haixu default tablespace users temporary tablespace temp;
查询是否存在该用户:(注意。尽管上面创建用户是的username是小写的hrman可是在数据库中存入的username字为:HRMAN)
select username account_status created from dba_users where username='HRMAN';
应用场景40:在Enterprise Manager中改动用户属性
应用场景41:使用ALTER USER 语句改动用户信息
1、改动用户口令:
ALTER USER<USERNAME> IDENTIFIED BY< NEW PASSWORD>
EG:ALTER USER USERMAN IDENTIFIED BY NEWPASSWROD;
2.设置口令过期:
ALTER USER USERMAN PASSWROD EXPIRE;
3.锁定用户:
ALTER USER USERMAN ACCOUNT LOCK;
4.解锁用户
ALTER USER USERMAN ACCOUNT UNLOCK;
应用场景42:在Enterprise Manager管理用户权限
应用场景43:使用SQL语句管理用户权限
1.GRANT<心痛权限> TO <username>
EG:GRANT SYSDBA TO HRMAN;
GRANT CREATE SESSION TO HRMAN;
GRANT CREATE TABLE TO HRMAN;
GRANT CREATE SEQUENCE TO HRMAN;
授予创建用户、改动、删除用户权限
GRANT CREATE USER,ALTER USER,DROP USER, TO HRMAN;
2.授予数据对象权限
GRANT < 数据对象权限>ON<数据对象>TO<username>
EG:GRANT SELECT ON HRMAN USERS TO DEPARTMENT;
GRANT INSERT ON HRMAN USERS TO DEPARTMENT;
GRANT UPDATE ON HRMAN USERS TO DEPARTMENT;
GRANT DELETE ON HRMAN USERS TO DEPARTMENT;
3.撤销用户权限
REVOKE <权限或角色>FROM<username>
eg:REVOKE SYSDBA FROM HRMAN;
应用场景44:为应用分配空间配额
为用户在指定的表空间中能够占用的空间大小。
ALTER USER<username>QUOTA<空间配额的大小>ON<表空间>
eg:ALTER USER HRMAN QUOTA 100M ON USERS;
应用场景45:删除用户
DROP USER HRMAN;
应用场景46:查看用户回话信息
COL USERNAME FORMAT A10
COL USER# FORMAT A10
COL TYPE FORMAT A10
COL LOGON_TIME A20
COL PROCESS FORMAT A10
COL PROGRAM FORMAT A20
SELECT USERNAME,USER#,TYPE,LOGON_TIME,PROCESS,PROGRAM,STATUS FROM V$SESSION;
应用场景47:查看用户权限信息
COL GRANTEE FROMAT A15
COL TABLE_NAME FORMAT A15
COL PRIVIEGE FORMAT A15
COL PRIVILEGE FORMAT A15
SELECT GRANTEE,TABLE_NAME,PRIVILEGE GRANTOR FROM DBA_TAB_PRIVS WHERE ROWNUM<=10;
应用场景48:使用口令文件
ORAPWD FILE = filename PASSWORD = password ENTRIES = max_users force = <y/n>
视图V$PWFILE_USERS中存放了口令文件的信息,
SELECT * FROM V$PWFILE_USERS;
应用场景49:忘记DBA口令的解决方法
以SYSDBA身份连接到SQLPlus:
sqlplus "/as sysdba"
改动sys的用户口令为newpassword:
ALTER USER SYS IDENTIFIED BY NEWPASSWROD;
COMMIT;
最后測试连接:
CONN SYS /AS SYSDBA
输入口令:
newpassword
应用场景50:查看角色的信息
SELECT * FROM DBA_ROLES;CONN
应用场景51:在Enterprise Manager中创建角色
应用场景52:使用CREATE ROLE语句创建角色
CREATE ROLE<角色名>IDENTIFIED BY <验证口令>
eg: CREATE ROLE MYROLE1 IDENTIFIED BY MYROLEPWD;
应用场景53:对角色授权
应用场景54:指定用户的角色
GRANT <ROLE>TO <USERNAME>
EG:GRANT CONNECT TO HRMAN;
使用REVOKE取消用户角色:
REVOKE <ROLES> FROM<USERNAME>
EG:REVOKE CONNECT FROM HRMAN;
应用场景55:改动角色属性
取消角色的口令验证.丢弃角色
ALTER ROLE MYROLE1 NOT IDENTIFIED;
应用场景56:删除角色
DROP ROLE MYROLE1;
应用场景57:查看用户的角色信息
SELECT * FROM DBA_ROLE_PRIVS;
Oracle442个应用场景-----------角色管理的更多相关文章
- MySQL 8.0用户和角色管理
MySQL 8.0用户和角色管理 MySQL8.0新加了很多功能,其中在用户管理中增加了角色的管理,默认的密码加密方式也做了调整,由之前的sha1改为了sha2,同时加上5.7的禁用用户和用户过期的设 ...
- 循序渐进VUE+Element 前端应用开发(16)--- 组织机构和角色管理模块的处理
在前面随笔<循序渐进VUE+Element 前端应用开发(15)--- 用户管理模块的处理>中介绍了用户管理模块的内容,包括用户列表的展示,各种查看.编辑.新增对话框的界面处理和后台数据处 ...
- SQL Server 2012 新特性:服务角色管理
数据库角色管理,已经可以使用alter role,create role和drop role. 2012增加了几个ddl语句,可以操作服务级别的角色管理, CREATE SERVER ROLE 用 ...
- 七天学会ASP.NET MVC (五)——Layout页面使用和用户角色管理
系列文章 七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC 七天学会ASP.NET MVC (二)——ASP.NET MVC 数据传递 七天学会ASP.NET MVC (三)— ...
- Module Zero之角色管理
返回<Module Zero学习目录> 角色实体 角色管理者 多租户 角色实体 角色实体代表了该应用的一个角色.它应该派生自AbpRole类,如下所示: public class Role ...
- roleManager与角色管理授权
总览地址 https://msdn.microsoft.com/zh-cn/library/9ab2fxh0.aspx 其中基本概述是第一篇:了解角色管理 来自 <https://msdn.mi ...
- 安装 SQL SERVER 2008 必须使用 "角色管理工具" 错误 的 解决方案 (转)
刚在服务器(Win2008)上安装SqlServer2008的时候出现了这么一个报错——必须使用“角色管理工具”安装或配置Microsoft .NET Framework 3.5 SP1.一开始以为是 ...
- RDIFramework.NET ━ 9.4 角色管理 ━ Web部分
RDIFramework.NET ━ .NET快速信息化系统开发框架 9.4 角色管理 -Web部分 角色管理模块主要为了方便框架权限的分配,提高权限分配的效率,减少重复设置权限的工作量.角色(用户组 ...
- 必须使用“角色管理工具”安装或配置Microsoft .NET Framework 3.5 SP1
在Windows Server 2008下直接安装SQL Server 2008时,会出现如下错误: 必须使用“角色管理工具”安装或配置Microsoft .NET Framework 3.5 SP1 ...
随机推荐
- JavaNIO阻塞IO
package com.java.NIO; import java.io.IOException; import java.net.InetSocketAddress; import java.nio ...
- eclipse中删除多余的tomcat server
在eclipse菜单中选择Window--Show View--Server--Servers,打开这个服务窗口,将多余的服务删除即可. 如果每次启动中太卡没反应,那就是服务没选择好,或是端口冲突的原 ...
- AngularJS学习篇(一)
AngularJS 使用 表达式 把数据绑定到 HTML. AngularJS 表达式 AngularJS 表达式写在双大括号内:{{ expression }}. AngularJS 表达式把数据绑 ...
- JavaScript系列----数据类型以及传值和传引用
1.简单数据类型 在JavaScript中简单数据类型分为5种.分别为 Undefined, Null,Boolean,Number,String. Undefined类型Undefined类型只有一 ...
- 使用Docker安装Mysql
最近使用阿里云服务器,学习一下Docker,今天学着使用Docker安装MySQL. 首先,从阿里云的Docker Hub 上pull一个MySQL的image. [centos@loovelj~]$ ...
- Scanner扫描器
扫描器 : Scanner 接收用户在键盘上的输入内容 是Java自带的一个工具,但是默认情况下没有在我们写的程序中使用三个步骤:1. 导入扫描器 : 导入类文件 import java.u ...
- 使用Docker跑MySQL 作为Django的存储后端
Docker的好处不科普了,用过的都说好. 不想污染自己开发机器上的文件环境,本萌新使用Docker运行Mysql,Redis来作为Django的存储后端和缓存. 在第一次安装过程中,我遇到了一些问题 ...
- 打印中文dict list的各种姿势
在开发过程中,我们经常需要打印一些变量的值,便于调试.这个时候就会发现如果在dict list这些容器中,如果包含中文字符,不管是str类型,还是unicode类型,都打印不出来.如下: >&g ...
- ThreeJS的特效合成器和后期处理通道
最近要写个 web 交互式发光可交互的框架.没查到啥好资料,自己一个人摸索了很久,有些失望,可是毕竟是探索过的东西,所以做个记录,怀念我过去好多天掉的青丝(捂脸).我在前面那篇博客里面已经介绍了如何让 ...
- 后端自动化版本管理,再也不用改URL了!
每次升级接口版本时,后端.前端.客户端都是痛苦的: 后端:要兼容旧版客户端,以前的接口不能动啊,又得写新接口.新文档了,唉! 前端:还好,就是版本号到处都是,改起来比较烦. Android:快点啊产品 ...