zoukankan      html  css  js  c++  java
  • Oracle 用户管理权限

    Oracle 用户管理权限

    一、创建用户的Profile文件

    SQL> create profile student limit // student为资源文件名

    FAILED_LOGIN_ATTEMPTS 3 //指定锁定用户的登录失败次数

    PASSWORD_LOCK_TIME 5 //指定用户被锁定天数

    PASSWORD_LIFE_TIME 30 //指定口令可用天数

    二、创建用户

    SQL> Create User username

    Identified by password  --密码,全是数字双引号,

    Default Tablespace tablespace--默认表空间,

    Temporary Tablespace tablespace--零时表空间

    Profile profile--用户使用数据保存,

    Quota integer/unlimited on tablespace;

    ---

    create tablespace test_tablespace

    datafile 'd:oracleoradata est est.dbf'

    size 100M

    创建表空间的语句

    注意表空间的创建必须指定datafile以及文件的大小

    例:

    SQL> Create user acc01

    identified by acc01 // 如果密码是数字,请用双引号括起来

    default tablespace account

    temporary tablespace temp

    profile default

    quota 50m on account;--最多50兆

    SQL> grant connect, resource to acc01;

    [*] 查询用户缺省表空间、临时表空间

    SQL> select username, default_tablespace, temporary_tablespace from dba_users;

    [*] 查询系统资源文件名:

    SQL> select * from dba_profiles;

    资源文件类似表,一旦创建就会保存在数据库中。

    SQL> select username, profile, default_tablespace, temporary_tablespace from dba_users;

    SQL> create profile common limit

    failed_login_attempts 5

    idle_time 5;

    SQL> Alter user acc01 profile common;

    三、修改用户:

    SQL> Alter User 用户名

    Identified 口令

    Default Tablespace tablespace

    Temporary Tablespace tablespace

    Profile profile

    Quota integer/unlimited on tablespace;

    1、修改口令字:

    SQL>Alter user acc01 identified by "12345";

    2、修改用户缺省表空间:

    SQL> Alter user acc01 default tablespace users;

    3、修改用户临时表空间

    SQL> Alter user acc01 temporary tablespace temp_data;

    4、强制用户修改口令字:

    SQL> Alter user acc01 password expire;

    5、将用户加锁

    SQL> Alter user acc01 account lock; // 加锁

    SQL> Alter user acc01 account unlock; // 解锁

    四、删除用户

    SQL>drop user 用户名; //用户没有建任何实体

    SQL> drop user 用户名 CASCADE; // 将用户及其所建实体全部删除

    *1. 当前正连接的用户不得删除。

    五、监视用户:

    1、查询用户会话信息:

    SQL> select username, sid, serial#, machine from v$session;

    2、删除用户会话信息:

    SQL> Alter system kill session 'sid, serial#';

    3、查询用户SQL语句:

    SQL> select user_name, sql_text from v$open_cursor;

    ORACLE用户权限管理整理

    select username from dba_users;  查询系统所有用户

    select * from dba_users where username = 'XXXX';查询用户相关信息

    select * from dba_roles;    查询系统所有角色

    DBA_ROLE_PRIVS        查询某个用户具有的角色或者某个角色下的有哪些用户

    select * from dba_role_privs where grantee ='SYS';

    select * fromdba_role_privs where granted_role ='RESOURCE';

    DBA_SYS_PRIVS   查询某个用户具有的系统权限

    select grantee,privilege from dba_sys_privs where grantee='XXXX';

    ROLE_SYS_PRIVS显示授予角色的系统权限

    select* from role_sys_privs where role = 'RESOURCE';查询RESOURCE角色相关的权限

    ROLE_TAB_PRIVS显示授予角色的表权限

    管理用户、角色和权限的DBA视图:

    DBA_USERS         提供用户的信息

    DBA_ROLES         显示数据库中所有角色

    DBA_COL_PRIVS     显示列级对象授权

    DBA_ROLE_PRIVS    显示用户及其角色

    DBA_SYS_PRIVS     显示被授予系统权限的用户

    DBA_TAB_PRIVS     显示用户及他们在表上的权限

    ROLE_ROLE_PRIVS   显示授予角色的角色

    ROLE_SYS_PRIVS    显示授予角色的系统权限

    ROLE_TAB_PRIVS    显示授予角色的表权限

    SESSION_PRIVS     显示允许用户使用的权限

    SESSION_ROLES     显示当前允许用户使用的角色

    select * from session_privs;查询用户本身拥有的权限

    select * from user_role_privs;查询用户本身拥有的角色

    select * from dba_sys_privs where grantee='CONNECT'; 查询角色所拥有的权限

    select * from role_sys_privs where role='CONNECT';查询角色所拥有的权限

    一、权限分类:

    系统权限:系统规定用户使用数据库的权限。(系统权限是对用户而言)。

    实体权限:某种权限用户对其它用户的表或视图的存取权限。(是针对表或视图而言的)。

    二、系统权限管理:

    1、系统权限分类:

    DBA: 拥有全部特权,是系统最高权限,只有DBA才可以创建数据库结构。

    RESOURCE:拥有Resource权限的用户只可以创建实体,不可以创建数据库结构。

    CONNECT:拥有Connect权限的用户只可以登录Oracle,不可以创建实体,不可以创建数据库结构。

    对于普通用户:授予connect, resource权限。

    对于DBA管理用户:授予connect,resource, dba权限。

    2、系统权限授权命令:

    [系统权限只能由DBA用户授出:sys, system(最开始只能是这两个用户)]

    授权命令:SQL> grant connect, resource, dba to 用户名1 [,用户名2]...;

    [普通用户通过授权可以具有与system相同的用户权限,但永远不能达到与sys用户相同的权限,system用户的权限也可以被回收。]

    例:

    SQL> connect system/manager

    SQL> Create user user50 identified by user50;

    SQL> grant connect, resource to user50;

    查询用户拥有哪里权限:

    SQL> select * from dba_role_privs;

    SQL> select * from dba_sys_privs;

    SQL> select * from role_sys_privs;

    删除用户:SQL> drop user 用户名 cascade;  //加上cascade则将用户连同其创建的东西全部删除

    3、系统权限传递:

    增加WITH ADMIN OPTION选项,则得到的权限可以传递。

    SQL> grant connect, resorce to qwith admin option;  //可以传递所获权限。

    4、系统权限回收:系统权限只能由DBA用户回收

    命令:SQL> Revoke connect, resource from user50;

    说明:

    1)如果使用WITH ADMIN OPTION为某个用户授予系统权限,那么对于被这个用户授予相同权限的所有用户来说,取消该用户的系统权限并不会级联取消这些用户的相同权限。

    2)系统权限无级联,即A授予B权限,B授予C权限,如果A收回B的权限,C的权限不受影响;系统权限可以跨用户回收,即A可以直接收回C用户的权限。

    三、实体权限管理

    1、实体权限分类:select, update, insert, alter, index, delete, all  //all包括所有权限

    execute  //执行存储过程权限

    user01:

    SQL> grant select, update, insert on product to user02;

    SQL> grant all on product to user02;

    user02:

    SQL> select * from user01.product;

    // 此时user02查user_tables,不包括user01.product这个表,但如果查all_tables则可以查到,因为他可以访问。

    2. 将表的操作权限授予全体用户:

    SQL> grant all on product to public;  // public表示是所有的用户,这里的all权限不包括drop。

    [实体权限数据字典]:

    SQL> select owner, table_name from all_tables; // 用户可以查询的表

    SQL> select table_name from user_tables;  // 用户创建的表

    SQL> select grantor, table_schema, table_name, privilege from all_tab_privs; // 获权可以存取的表(被授权的)

    SQL> select grantee, owner, table_name, privilege from user_tab_privs;   // 授出权限的表(授出的权限)

    3. DBA用户可以操作全体用户的任意基表(无需授权,包括删除):

    DBA用户:

    SQL> Create table stud02.product(

    id number(10),

    name varchar2(20));

    SQL> drop table stud02.emp;

    SQL> create table stud02.employee

    as

    select * from scott.emp;

    4. 实体权限传递(with grant option):

    user01:

    SQL> grant select, update on product to user02 with grant option; // user02得到权限,并可以传递。

    5. 实体权限回收:

    user01:

    SQL>Revoke select, update on product from user02;  //传递的权限将全部丢失。

    说明

    1)如果取消某个用户的对象权限,那么对于这个用户使用WITH GRANT OPTION授予权限的用户来说,同样还会取消这些用户的相同权限,也就是说取消授权时级联的。

    总结:

    --查看用户系统权限

      select * from dba_sys_privs;

      select * from session_privs;

      select * from user_sys_privs;

    --查看用户对象权限

      select * from dba_tab_privs;

      select * from all_tab_privs;

      select * from user_tab_privs;

    Oracle 角色管理

    一、何为角色

      角色。角色是一组权限的集合,将角色赋给一个用户,这个用户就拥有了这个角色中的所有权限。

    二、系统预定义角色

      预定义角色是在数据库安装后,系统自动创建的一些常用的角色。下介简单的介绍一下这些预定角色。角色所包含的权限可以用以下语句查询:

    sql>select * from role_sys_privs where role='角色名';

    1.CONNECT, RESOURCE, DBA

    这些预定义角色主要是为了向后兼容。其主要是用于数据库管理。oracle建议用户自己设计数据库管理和安全的权限规划,而不要简单的使用这些预定角色。将来的版本中这些角色可能不会作为预定义角色。

    2.DELETE_CATALOG_ROLE, EXECUTE_CATALOG_ROLE, SELECT_CATALOG_ROLE

    这些角色主要用于访问数据字典视图和包。

    3.EXP_FULL_DATABASE, IMP_FULL_DATABASE

    这两个角色用于数据导入导出工具的使用。

    4.AQ_USER_ROLE, AQ_ADMINISTRATOR_ROLE

    AQ:Advanced Query。这两个角色用于oracle高级查询功能。

    5. SNMPAGENT

    用于oracle enterprise manager和Intelligent Agent

    6.RECOVERY_CATALOG_OWNER

    用于创建拥有恢复库的用户。关于恢复库的信息,参考oracle文档《Oracle9i User-Managed Backup and Recovery Guide》

    7.HS_ADMIN_ROLE

    A DBA using Oracle's heterogeneous services feature needs this role to access appropriate tables in the data dictionary.

    三、管理角色

    1.建一个角色

    sql>create role role1;

    2.授权给角色

    sql>grant create any table,create procedure to role1;

    3.授予角色给用户

    sql>grant role1 to user1;

    4.查看角色所包含的权限

    sql>select * from role_sys_privs;

    5.创建带有口令以角色(在生效带有口令的角色时必须提供口令)

    sql>create role role1 identified by password1;

    6.修改角色:是否需要口令

    sql>alter role role1 not identified;

    sql>alter role role1 identified by password1;

    7.设置当前用户要生效的角色

    (注:角色的生效是一个什么概念呢?假设用户a有b1,b2,b3三个角色,那么如果b1未生效,则b1所包含的权限对于a来讲是不拥有的,只有角色生效了,角色内的权限才作用于用户,最大可生效角色数由参数MAX_ENABLED_ROLES设定;在用户登录后,oracle将所有直接赋给用户的权限和用户默认角色中的权限赋给用户。)

    sql>set role role1;//使role1生效

    sql>set role role,role2;//使role1,role2生效

    sql>set role role1 identified by password1;//使用带有口令的role1生效

    sql>set role all;//使用该用户的所有角色生效

    sql>set role none;//设置所有角色失效

    sql>set role all except role1;//除role1外的该用户的所有其它角色生效。

    sql>select * from SESSION_ROLES;//查看当前用户的生效的角色。

    8.修改指定用户,设置其默认角色

    sql>alter user user1 default role role1;

    sql>alter user user1 default role all except role1;

    详见oracle参考文档

    9.删除角色

    sql>drop role role1;

    角色删除后,原来拥用该角色的用户就不再拥有该角色了,相应的权限也就没有了。

    说明:

    1)无法使用WITH GRANT OPTION为角色授予对象权限

    2)可以使用WITH ADMIN OPTION 为角色授予系统权限,取消时不是级联

    数据字典

    1、动态数据字典是以v$xxx开始的数据字典,在数据库中约有150个左右,这些数据字典反映数据库动态运行状况,在不同时间查询会得到不同的结果。

    2、DBA数据字典是以DBA_xxx表示,该数据字典存储数据库结构,查询DBA数据字典可以反映数据库结构设置,管理磁盘空间和表空间、事务与回退段、用户与表空间等信息。

    3、用户数据字典是以USER_xxx表示,这些数据字典反应用户所创建的实体信息。如,USER_TABLES、USER_VIEWS,数据库管理员具有操作全体用户所有实体的权限,可以查询这类数据字典,了解用户所创建实体状况,必要时可以将用户创建的不正确的实体删除。

    4、ALL_xxx类数据字典,表示用户所创建的实体及用户有权可以存取的实体。

    select privilege from dba_SYS_privs where grantee=‘USERNAME’

    Oracle查询用户权限

    -- 确定角色的权限

    select * from role_tab_privs ; 包含了授予角色的对象权限

    select * from role_role_privs ; 包含了授予另一角色的角色

    select * from role_sys_privs ; 包含了授予角色的系统权限

    -- 确定用户帐户所授予的权限

    select * from DBA_tab_privs ; 直接授予用户帐户的对象权限

    select * from DBA_role_privs ; 授予用户帐户的角色

    select * from DBA_sys_privs ; 授予用户帐户的系统权限

    查看当前用户权限:

    SQL> select * from session_privs;

    PRIVILEGE

    ----------------------------------------

    CREATE SESSION

    CREATE TABLE

    CREATE CLUSTER

    CREATE SYNONYM

    CREATE VIEW

    CREATE SEQUENCE

    CREATE PROCEDURE

    CREATE TRIGGER

    8 rows selected.

    Oracle 本身的数据字典设计我个人觉得很合理, 因为DBA_xxx, ALL_xxx,USER_xxx 让人一看大概就知道这个视图是干什么用的. 本文简要总结了一下与权限,角色相关的视图.

    一. 概述

    与权限,角色相关的视图大概有下面这些:

    DBA_SYS_PRIVS: 查询某个用户所拥有的系统权限

    USER_SYS_PRIVS: 当前用户所拥有的系统权限

    SESSION_PRIVS: 当前用户所拥有的全部权限

    ROLE_SYS_PRIVS: 某个角色所拥有的系统权限

    注意: 要以SYS用户登陆查询这个视图,否则返回空.

    ROLE_ROLE_PRIVS: 当前角色被赋予的角色

    SESSION_ROLES: 当前用户被激活的角色

    USER_ROLE_PRIVS: 当前用户被授予的角色

    另外还有针对表的访问权限的视图:

    TABLE_PRIVILEGES

    ALL_TAB_PRIVS

    ROLE_TAB_PRIVS: 某个角色被赋予的相关表的权限

    ...

    二. Examples

    1. 查询当前用户所拥有的权限

    Select * from session_privs;

    2. 查询某个用户被赋予的系统权限.

    可以有多种方式

    Select * from user_sys_privs;

    或者: select * from DBA_SYS_PRIVS where grantee='XXX'

    (需要当前用户拥有DBA角色)

    3. 查询当前用户被授予的角色:

    1. Select * from SESSION_ROLES order by ROLE

    说明: 这个查询会返回当前用户所被授予的全部角色, 其中包括

    嵌套授权的角色. 例如将DBA角色授予了一个用户,DBA角色

    已经被授予的角色(例如 exp_full_database 和 imp_full_database)

    也会被查询出来

    2. Select * from USER_ROLE_PRIVS

    4. 查询某一角色被赋予的系统权限

    Select Privilege from ROLE_SYS_PRIVS where ROLE=&Role

    输入 role='CONNECT'

    输出:

    PRIVILEGE

    --------------------

    ALTER SESSION

    CREATE CLUSTER

    CREATE DATABASE LINK

    CREATE SEQUENCE

    CREATE SESSION

    CREATE SYNONYM

    CREATE TABLE

    CREATE VIEW

    5. 查询当前角色被授予的角色

    Select GRANTED_ROLE from ROLE_ROLE_PRIVS where ROLE=&ROLE

    输入 role= 'DBA'

    输出:

    GRANTED_ROLE

    ----------------------

    DELETE_CATALOG_ROLE

    EXECUTE_CATALOG_ROLE

    EXP_FULL_DATABASE

    IMP_FULL_DATABASE

    PLUSTRACE

    SELECT_CATALOG_ROLE

    说明: PLUSTRACE这个角色是用于执行SQL AUTO TRACE的, 通过执行

    $ORACLE_HOME/sqlplus/admin/plustrce.sql可以生成这个角色.

    -------------------------------------------------------------------------------------------------------------------------------------------------------------

    如何查看oracle用户权限?

    ORACLE数据字典视图的种类分别为:USER,ALL 和 DBA。

    USER_*:有关用户所拥有的对象信息,即用户自己创建的对象信息

    ALL_*:有关用户可以访问的对象的信息,即用户自己创建的对象的信息加上

    其他用户创建的对象但该用户有权访问的信息

    DBA_*:有关整个数据库中对象的信息

    (这里的*可以为TABLES,INDEXES,OBJECTS,USERS等。)

    1、查看所有用户

    select * from dba_user;

    select * from all_users;

    select * from user_users;

    2、查看用户系统权限

    select * from dba_sys_privs;

    select * from all_sys_privs;

    select * from user_sys_privs;

    3、查看用户对象权限

    select * from dba_tab_privs;

    select * from all_tab_privs;

    select * from user_tab_privs;

    4、查看所有角色

    select * from dba_roles;

    5、查看用户所拥有的角色

    select * from dba_role_privs;

    select * from user_role_privs;

    6、查看当前用户的缺省表空间

    select username,default_tablespace from user_users;

    7、查看某个角色的具体权限

      如grant connect,resource,create session,create view to TEST;

    8、查看RESOURCE具有那些权限

      用SELECT * FROM DBA_SYS_PRIVS WHERE GRANTEE='RESOURCE';

    oracle的系统和对象权限列表

    alter any cluster 修改任意簇的权限

    alter any index 修改任意索引的权限

    alter any role 修改任意角色的权限

    alter any sequence 修改任意序列的权限

    alter any snapshot 修改任意快照的权限

    alter any table 修改任意表的权限

    alter any trigger 修改任意触发器的权限

    alter cluster 修改拥有簇的权限

    alter database 修改数据库的权限

    alter procedure 修改拥有的存储过程权限

    alter profile 修改资源限制简表的权限

    alter resource cost 设置佳话资源开销的权限

    alter rollback segment 修改回滚段的权限

    alter sequence 修改拥有的序列权限

    alter session 修改数据库会话的权限

    alter sytem 修改数据库服务器设置的权限

    alter table 修改拥有的表权限

    alter tablespace 修改表空间的权限

    alter user 修改用户的权限

    analyze 使用analyze命令分析数据库中任意的表、索引和簇

    audit any 为任意的数据库对象设置审计选项

    audit system 允许系统操作审计

    backup any table 备份任意表的权限

    become user 切换用户状态的权限

    commit any table 提交表的权限

    create any cluster 为任意用户创建簇的权限

    create any index 为任意用户创建索引的权限

    create any procedure 为任意用户创建存储过程的权限

    create any sequence 为任意用户创建序列的权限

    create any snapshot 为任意用户创建快照的权限

    create any synonym 为任意用户创建同义名的权限

    create any table 为任意用户创建表的权限

    create any trigger 为任意用户创建触发器的权限

    create any view 为任意用户创建视图的权限

    create cluster 为用户创建簇的权限

    create database link 为用户创建的权限

    create procedure 为用户创建存储过程的权限

    create profile 创建资源限制简表的权限

    create public database link 创建公共数据库链路的权限

    create public synonym 创建公共同义名的权限

    create role 创建角色的权限

    create rollback segment 创建回滚段的权限

    create session 创建会话的权限

    create sequence 为用户创建序列的权限

    create snapshot 为用户创建快照的权限

    create synonym 为用户创建同义名的权限

    create table 为用户创建表的权限

    create tablespace 创建表空间的权限

    create user 创建用户的权限

    create view 为用户创建视图的权限

    delete any table 删除任意表行的权限

    delete any view 删除任意视图行的权限

    delete snapshot 删除快照中行的权限

    delete table 为用户删除表行的权限

    delete view 为用户删除视图行的权限

    drop any cluster 删除任意簇的权限

    drop any index 删除任意索引的权限

    drop any procedure 删除任意存储过程的权限

    drop any role 删除任意角色的权限

    drop any sequence 删除任意序列的权限

    drop any snapshot 删除任意快照的权限

    drop any synonym 删除任意同义名的权限

    drop any table 删除任意表的权限

    drop any trigger 删除任意触发器的权限

    drop any view 删除任意视图的权限

    drop profile 删除资源限制简表的权限

    drop public cluster 删除公共簇的权限

    drop public database link 删除公共数据链路的权限

    drop public synonym 删除公共同义名的权限

    drop rollback segment 删除回滚段的权限

    drop tablespace 删除表空间的权限

    drop user 删除用户的权限

    execute any procedure 执行任意存储过程的权限

    execute function 执行存储函数的权限

    execute package 执行存储包的权限

    execute procedure 执行用户存储过程的权限

    force any transaction 管理未提交的任意事务的输出权限

    force transaction 管理未提交的用户事务的输出权限

    grant any privilege 授予任意系统特权的权限

    grant any role 授予任意角色的权限

    index table 给表加索引的权限

    insert any table 向任意表中插入行的权限

    insert snapshot 向快照中插入行的权限

    insert table 向用户表中插入行的权限

    insert view 向用户视图中插行的权限

    lock any table 给任意表加锁的权限

    manager tablespace 管理(备份可用性)表空间的权限

    references table 参考表的权限

    restricted session 创建有限制的数据库会话的权限

    select any sequence 使用任意序列的权限

    select any table 使用任意表的权限

    select snapshot 使用快照的权限

    select sequence 使用用户序列的权限

    select table 使用用户表的权限

    select view 使用视图的权限

    unlimited tablespace 对表空间大小不加限制的权限

    update any table 修改任意表中行的权限

    update snapshot 修改快照中行的权限

    update table 修改用户表中的行的权限

    update view 修改视图中行的权限

    与权限安全相关的数据字典表有:

    ALL_TAB_PRIVS

    ALL_TAB_PRIVS_MADE

    ALL_TAB_PRIVS_RECD

    DBA_SYS_PRIVS

    DBA_ROLES

    DBA_ROLE_PRIVS

    ROLE_ROLE_PRIVS

    ROLE_SYS_PRIVS

    ROLE_TAB_PRIVS

    SESSION_PRIVS

    SESSION_ROLES

    USER_SYS_PRIVS

    USER_TAB_PRIV

  • 相关阅读:
    mysql相关笔记
    qt杂项
    rpm离线安装整理
    linux fopen个数限制的问题(文件描述符限制)
    解决free():invalid pointer:0x00000000000000155455 ****的问题。
    linux c获取系统时间戳
    ubuntu QT Creater 安装
    LinkedHashMap如何保证顺序性
    HashMap原理(二) 扩容机制及存取原理
    HashMap原理(一) 概念和底层架构
  • 原文地址:https://www.cnblogs.com/czg-0705/p/11391910.html
Copyright © 2011-2022 走看看