`

Oracle 数据库用户管理

 
阅读更多
Oracle 数据库用户管理
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 用户名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 user50 with admin option;  //可以传递所获权限。
4、系统权限回收:系统权限只能由DBA用户回收
命令:SQL> Revoke connect, resource from user50;
系统权限无级联,即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则可以查到,因为他可以访问。

3. 将表的操作权限授予全体用户:
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;   // 授出权限的表(授出的权限)
4. 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;

5. 实体权限传递(with grant option):
user01:
SQL> grant select, update on product to user02 with grant option; // user02得到权限,并可以传递。
6. 实体权限回收:
user01:
SQL>Revoke select, update on product from user02;  //传递的权限将全部丢失。

一、创建用户的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;
例:
SQL> Create user acc01
identified by acc01   // 如果密码是数字,请用双引号括起来
default tablespace account
temporary tablespace temp
profile default
quota 50m on account;
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;
    SQL> ALTER SESSION SET
    NLS_LANGUAGE= 'SIMPLIFIED CHINESE'
    NLS_TERRITORY= 'CHINA'
    NLS_CURRENCY= 'RMB'
    NLS_ISO_CURRENCY= 'CHINA'
    NLS_NUMERIC_CHARACTERS= '.,'
    NLS_CALENDAR= 'GREGORIAN'
    NLS_DATE_FORMAT= 'yyyy-mm-dd dy'
    NLS_DATE_LANGUAGE= 'SIMPLIFIED CHINESE' 
    NLS_SORT= 'BINARY'
    TIME_ZONE= '+08:00'
    NLS_DUAL_CURRENCY = 'RMB'
    NLS_TIME_FORMAT = 'HH.MI.SSXFF AM'
    NLS_TIMESTAMP_FORMAT = 'DD-MON-RR HH.MI.SSXFF AM'
    NLS_TIME_TZ_FORMAT = 'HH.MI.SSXFF AM TZH:TZM'
    NLS_TIMESTAMP_TZ_FORMAT = 'DD-MON-RR HH.MI.SSXFF AM TZH:TZM'


    一、Oracle 权限管理
    SQL> grant connect, resource, dba to acc01;
    SQL> revoke connect, resource from acc01;
    二、Oracle 角色管理
    SQL> Create Role <role_name>
    Identified by password/ Not Identified;

    SQL> Alter Role <role_name> ...
    SQL> Grant <privs> to <role_name>;
    SQL> Grant <role_name> to <user_name>
    SQL> Set Role <role_name>
    All Except <role_name2> / None 
    转自 http://dusong.blog.51cto.com/158065/139284
    分享到:
    评论

    相关推荐

      oracle数据库用户管理

      Oracle数据库用户管理是数据库系统中至关重要的一环,它关乎到数据的安全性和权限控制。Oracle数据库提供了丰富的用户管理和安全策略,确保只有授权的用户才能访问特定的数据资源。 首先,Oracle数据库的安全性可以...

      Oracle数据库用户管理笔记.doc

      Oracle 数据库用户管理笔记 Oracle 数据库用户管理是数据库管理员的重要任务之一。用户管理包括创建用户、管理用户权限、管理用户密码等。下面是 Oracle 数据库用户管理的重要知识点: 一、用户命名规则 Oracle ...

      Oracle数据库精讲之数据库管理_ Oracle数据库管理视频

      2. 提供oracle数据库dba日常管理方法。 3. 掌握oracle数据库体系机构,为oracle优化奠定基础。 三、适合人群: 1.有意从事oracle 数据库工作,担任dba角色的人员; 2. Oracle数据库设计、开发和备份等管理人员; ...

      查看登录oracle数据库用户记录.docx

      "查看登录 Oracle 数据库用户记录" Oracle 数据库是一个强大的关系型数据库管理系统,提供了强大...本文介绍了如何使用触发器来查看登录 Oracle 数据库用户记录,帮助数据库管理员更好地管理和监控数据库的访问情况。

      ORACLe数据库管理员教程

      DBA的职责广泛,包括理解Oracle数据库的体系结构、安装和升级数据库管理系统、控制数据库的启动和关闭、管理数据库用户、权限、存储空间以及执行数据库的备份和恢复操作。 Oracle数据库的体系结构主要由物理结构、...

      Oracle 数据库管理教程

      Oracle数据库管理是计算机科学中数据库管理系统领域的重要分支。Oracle数据库是一个大型、多层次、多用户的关系型数据库管理系统。为了深入学习和理解Oracle数据库管理,本教程将从数据库基础、Oracle服务器构成、...

      Oracle数据库管理员技术指南,Oracle数据库管理员技术指南

      ### Oracle数据库管理员技术指南:建立和配置数据库 在IT领域,尤其是数据库管理中,Oracle数据库因其卓越的性能和广泛的应用而备受青睐。对于希望成为Oracle数据库管理员(DBA)的专业人士而言,掌握创建和配置...

      Oracle 数据库管理.pdf

      Oracle数据库管理是IT行业中一项关键的技术,涉及到数据库的维护、优化、故障处理等多个方面。Oracle数据库是由甲骨文公司(Oracle Corporation)开发的一款关系型数据库管理系统,以其强大的功能、良好的可伸缩性和...

      oracle 数据库管理员指南

      Oracle数据库管理员指南是一本深入解析Oracle数据库管理的权威著作,对于从事大型数据库开发与分析的专业人士来说,它无疑是必备的参考资料。Oracle数据库是全球广泛使用的数据库管理系统之一,尤其在企业级应用中...

      Oracle数据库.pdf

      - `ALTER USER`语句用于管理数据库用户的属性。如在描述中所示,可以使用`ALTER USER scott ACCOUNT UNLOCK`解锁被锁定的用户scott,并用`ALTER USER scott IDENTIFIED BY tiger`设置新密码。 2. **数据字典查询**...

      Oracle数据库大作业

      【Oracle数据库大作业】是一个关于Oracle数据库在教务管理系统中的应用项目,可能涵盖了数据库设计、实施、优化等多个方面的内容。这个大作业包含了PPT演示文稿、Word文档以及可能的源代码,为学习者提供了全面了解...

      解锁或者修改oracle 数据库用户密码.doc

      Oracle 数据库用户密码的管理是非常重要的,一方面可以防止非法访问和数据泄露,另一方面可以确保数据库的安全性和可靠性。因此,数据库管理员应该定期检查和更新密码,以确保数据库的安全性。 四、结论 解锁或者...

      oracle数据库_实例_用户_表空间之间的关系

      Oracle 数据库实例用户表空间之间的关系是 Oracle 数据库管理系统的核心概念。了解它们之间的关系对于数据库的设计、管理和优化至关重要。 数据库 Oracle 数据库是一个物理存储单元,包括数据文件(ORA 或者 DBF)...

      Oracle数据库管理员

      Oracle数据库管理员是一个关键角色,负责管理和维护...以上内容涵盖了Oracle数据库管理中的核心概念,包括管理模式、用户权限、数据库标识、文件管理和连接方式等,这些都是数据库管理员日常工作中必须掌握的基础知识。

      动态导入oracle数据库

      在提供的内容中还涉及到了Oracle数据库用户管理的操作,例如: - **创建用户**:`create user 用户名 identified by 密码;` - **修改用户密码**:`alter user 用户名 identified by 新密码;` - **解锁用户账户**:`...

    Global site tag (gtag.js) - Google Analytics