Oracle用户权限及角色管理浅谈
http://database.51cto.com/art/200910/158945.htm
Oracle用户权限可以对用户或用户组进行管理和授权,制定可操作的功能范围。这里讲解的Oracle用户权限和角色的管理,全面介绍了Oralce用户系统中的两个重要理念,即系统权限和对象权限。
AD:
Oracle用户权限是指Oracle角色中的一组可执行操作范围,其实,每个Oracle用户都有一个名字和口令,拥有一些可以创建表、试图和资源。将某个角色赋予相应的用户,这些用户便具有了这些权限,同时,这些用户也可以给其他用户授权。
数据库系统权限(Database System Privilege)允许用户执行特定的命令集。例如,CREATE TABLE的Oracle用户权限允许用户创建表,GRANT ANY PRIVILEGE 权限允许用户授予任何系统权限。
数据库对象权限(Database Object Privilege)使得用户能够对各个对象进行某些操作。例如DELETE权限允许用户删除表或视图的行,SELECT权限允许用户通过select从表、视图、序列(sequences)或快照 (snapshots)中查询信息。
一、创建用户
Oracle内部有两个建好的用户:SYSTEM和SYS。用户可直接登录到SYSTEM用户以创建其他用户,因为SYSTEM具有创建别的Oracle用户权限。在安装Oracle时,用户或系统管理员首先可以为自己建立一个用户。例如:
create user user01 identified by u01;
该命令还可以用来设置其他权限,详细情况参见自学资料。要改变一个口令,可以使用alter user命令:
alter user user01 identified by usr01;
现在user01的口令已由“u01”改为“usr01”。
除了alter user命令以外,用户还可以使用password命令。如果使用password命令,用户输入的新口令将不在屏幕上显示。有dba特权的用户可以通过password命令改变任何其他用户的口令;其他用户只能改变自己的口令。
当用户输入password命令时,系统将提示用户输入旧口令和新口令,如下所示:
password Changing password for user01 Old password: New password: Retype new password: 当成功地修改了口令时,用户会得到如下的反馈:
Password changed
二、删除用户
删除用户,可以使用drop user命令,如下所示:
drop user user01;
如果用户拥有对象,则不能直接删除,否则将返回一个错误值。指定关键字CASCADE,可删除用户所有的对象,然后再删除用户。下面的例子用来删除用户与其对象:
drop user user01 CASCADE;
三、3种标准角色
Oracle为了兼容以前的版本,提供了三种标准的角色(role):CONNECT、RESOURCE和DBA。
1. CONNECT Role(连接角色)
临时用户,特别是那些不需要建表的用户,通常只赋予他们CONNECTrole。CONNECT是使用Oracle的简单权限,这种权限只有在对其他用户的表有访问权时,包括select、insert、update和delete等,才会变得有意义。拥有CONNECT role的用户还能够创建表、视图、序列(sequence)、簇(cluster)、同义词(synonym )、会话(session)和与其他数据库的链(link)。
2. RESOURCE Role(资源角色)
更可靠和正式的数据库用户可以授予RESOURCE role。RESOURCE提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器(trigger)、索引(index)和簇(cluster)。
3. DBA Role(数据库管理员角色)
DBA role拥有所有的系统权限----包括无限制的空间限额和给其他用户授予各种权限的能力。SYSTEM由DBA用户拥有。下面介绍一些DBA经常使用的典型权限。
(1)grant(授权)命令
下面对刚才创建的用户user01授权,命令如下:
grant connect, resource to user01;
(2)revoke(撤消)权限
已授予的权限可以撤消。例如撤消(1)中的授权,命令如下:
revoke connect, resource from user01;
一个具有DBA角色的用户可以撤消任何别的用户甚至别的DBA的CONNECT、RESOURCE 和DBA的其他权限。当然,这样是很危险的,因此,除非真正需要,DBA权限不应随便授予那些不是很重要的一般用户。
撤消一个用户的所有权限,并不意味着从Oracle中删除了这个用户,也不会破坏用户创建的任何表;只是简单禁止其对这些表的访问。其他要访问这些表的用户可以象以前那样地访问这些表。
四、创建角色
除了前面讲到的三种系统角色----CONNECT、RESOURCE和DBA,用户还可以在Oracle创建自己的role。用户创建的role可以由表或系统权限或两者的组合构成。为了创建role,用户必须具有CREATE ROLE系统权限。下面给出一个create role命令的实例:
create role STUDENT;
这条命令创建了一个名为STUDENT的role。
一旦创建了一个role,用户就可以给他授权。给role授权的grant命令的语法与对对用户的语法相同。在给role授权时,在grant命令的to子句中要使用role的名称,如下所示:
grant select on CLASS to STUDENT;
现在,拥有STUDENT角色的所有用户都具有对CLASS表的select权限。
五、删除角色
要删除角色,可以使用drop role命令,如下所示:
drop role STUDENT;
指定的role连同与之相关的Oracle用户权限将从数据库中全部删除。
【编辑推荐】
Oracle用户权限的创建及分配
Oracle默认用户名与密码速查表
在命令行下进行Oracle用户解锁
五种Oracle用户的授权与管理
五分钟精通Oracle表空间
【责任编辑:red7 TEL:(010)68476606】
http://database.51cto.com/art/200910/158945.htm
分享到:
相关推荐
Oracle数据库作为关系型数据库的代表,其安全性涉及多个层面,包括用户管理、权限管理、资源限制管理等。以下将详细阐述这些策略。 首先,数据库系统安全性要求主要包括完整性、保密性和可用性。完整性确保数据的...
Oracle提供角色概念来管理权限,通过角色可以将相关的权限集中管理,并一次性赋予多个用户。这不仅简化了权限管理,还为控制用户权限提供了更大的灵活性。数据库管理员同样需要关注自己的安全,通过定期更换密码和...
- 操作系统组和用户:为了允许操作系统用户直接登录Oracle,可以将用户加入如ORA_DBA或ORA_SID_DBA(针对特定实例)这样的组,这些组的成员自动具有SYSDBA权限。同样,ORA_OPER组成员具有SYSOPER角色。 - 登录方式...
3. 用户权限管理:通过网上购物系统的案例,教授Oracle数据库的安全管理,包括用户管理和权限管理,这些都是数据库管理员的基本技能。 4. 数据管理与SQL应用:通过网上购物系统的数据库实施,学习如何管理表对象、...
3. 角色和权限管理:Oracle支持角色的概念,可以将一组权限授予一个角色,便于管理和控制。 4. 网络安全性:Oracle提供网络认证和加密机制,保护数据在网络传输过程中的安全。 5. 审计功能:Oracle的审计功能记录...
Oracle 数据库是由Oracle公司开发的关系型数据库管理系统,是目前最新的版本Oracle 11g,被广泛应用于大型应用和超大型系统,因其优越的性能、基于角色的权限管理模式、大数据存储支持、分布式管理和独特的表空间...
在管理信息系统(MIS)的开发过程中,Oracle数据库的触发器是一个强大的工具,它允许开发者在特定事件发生时自动执行一系列操作,从而增强系统的功能和数据安全性。本文主要探讨了Oracle触发器的基础概念、类型,...
管理人员可以根据用户的工作性质和数据访问需求,授予不同的用户角色,并为不同角色授予不同的存取权限。这样的权限管理策略,可以在确保数据库安全的同时,允许用户根据授权进行合法操作,防止非法访问。 综上所述...
【文档标题】:“浅谈地铁档案管理系统与第三方应用系统的数据归档接口解决方案” 【文档描述】:本文档探讨了地铁档案管理系统与不同第三方应用系统之间的数据归档接口设计,特别是针对成都地铁档案管理系统与办公...
Oracle RAC,全称为Real Application Clusters,是Oracle数据库的一项高级特性,旨在提供高可用性、高性能和可扩展性的解决方案。Oracle RAC允许多个实例同时访问同一个物理数据库,通过共享存储来实现数据的分布式...
随着计算机技术的广泛应用,数据库在各行业中扮演着越来越重要的角色。从早期的FoxPro到广泛使用的Microsoft SQL Server、Oracle等,数据库技术经历了快速的发展。本文深入探讨了SQL Server数据库的安全技术,涉及...
在Oracle数据库中,数据导入导出是数据库管理的重要环节,用于备份、迁移或恢复数据。本文将详细介绍入门级的Oracle数据库数据导入导出步骤,以帮助初学者理解和实践。 首先,Oracle提供多种数据导入导出的方法,...
SSRS支持多种数据源,如SQL Server、SQL Server Analysis Services、Oracle、ODBC和OLEDB等,它能整合这些数据并生成特殊的数据格式,以此满足不同用户的信息和数据需求。此外,SSRS还提供多种输出展现格式,包括...