Oracle创建用户角色授权建表

Posted renwujie

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle创建用户角色授权建表相关的知识,希望对你有一定的参考价值。

--1.关闭与重启数据库

--进入管理员权限:sqlplus / as sysdba

--关闭数据库:shutdown immediate

--打开数据库:startup

--退出数据库:exit

--提示:需要先进入管理员权限才可以进行关闭和打卡数据库

--2.创建表空间

create tablespace test --(表空间的名字)

datafile ‘D:apphspcadminoradataorcl est.dbf‘

--(这边可以写成oracle的某个路径下,test.dbf 名称与表空间名称相同)

size 50m --(初始大小)

autoextend on; --(自动扩展)

--3.创建数据库用户

CREATE USER rwjtest --创建用户

IDENTIFIED BY rwjtest --用户密码

DEFAULT TABLESPACE test--使用刚创建的表空间

TEMPORARY TABLESPACE temp;--temp为临时表空间

alter user rwjtest IDENTIFIED by rwxtest;--更改用户的密码

--注意:以上三条的执行环境为连结上oracle数据库后,进行执行的。

--连结数据库命令(cmd环境下执行):sqlplus system/密码 回车即可

--4.删除用户,若用户拥有对象,则不能直接删除,否则将返回一个错误值。指定关键字cascade,可删除用户所有的对象,然后再删除用户。

drop user rwjtest;

drop user rwjtest cascade;

--5.oracle的三种表中权限角色,oracle数据库的权限系统分为系统权限与对象权限。

--系统权限( database system privilege )可以让用户执行特定的命令集。例如,create table权限允许用户创建表,grant any privilege权限

--允许用户授予任何系统权限。对象权限( database object privilege )可以让用户能够对各个对象进行某些操作。例如delete权限允许用户

--删除表或视图的行,select权限允许用户通过select从表、视图、序列(sequences)或快照(snapshots)中查询信息。每个oracle用户都有一个

--名字和口令,并拥有一些由其创建的表、视图和其他资源。oracle角色(role)就是一组权限(privilege)(或者是每个用户根据其状态和条件所需

--的访问类型)。用户可以给角色授予或赋予指定的权限,然后将角色赋给相应的用户。一个用户也可以直接给其他用户授权。

--5.1connect role(连接角色),临时用户,特指不需要建表的用户,通常只赋予他们connect role.

--connect是使用oracle简单权限,这种权限只对其他用户的表有访问权限,包括select/insert/update和delete等。

--拥有connect role 的用户还能够创建表、视图、序列(sequence)、簇(cluster)、同义词(synonym)、回话(session)和其他数据的链(link)

--5.2resource role(资源角色)

--更可靠和正式的数据库用户可以授予resource role。

--resource提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器(trigger)、索引(index)和簇(cluster)。

--5.3dba role(数据库管理员角色)

--dba role拥有所有的系统权限

--包括无限制的空间限额和给其他用户授予各种权限的能力。system由dba用户拥有

--6.赋予用户角色权限

GRANT CONNECT TO rwjtest;

GRANT RESOURCE TO rwjtest;

GRANT dba TO rwjtest; --dba为最高级权限,可以创建数据库,表等。

--7.撤销用户权限, revoke connect, resource,dba from 用户名;

revoke connect, resource,dba from rwjtest;

--8.创建/授权/删除角色

--除了前面讲到的三种系统角色----connect、resource和dba,用户还可以在oracle创建自己的role。用户创建的role可以由表或系统权限或两者的组合构成。为了创建role,用户必须具有create role系统权限。

--8.1创建角色--create role 角色名

--create role testRole;

--8.2授权角色--grant select on 表名 to 角色名

--grant select on t_user to testRole;--现在,拥有testRole角色的所有用户都具有对class表的select查询权限.

--8.3删除角色--drop role 角色名

--drop role testRole;--与testRole角色相关的权限将从数据库全部删除.

以上是关于Oracle创建用户角色授权建表的主要内容,如果未能解决你的问题,请参考以下文章

Oracle创建用户角色授权建表(转)

Oracle创建用户角色授权建表空间

Oracle创建用户角色授权建表

oracle数据库控制已建表在不同用户下拥有不同权限

oracle创建用户创建表空间授权建表

oracle一个创建用户创建表空间授权建表的完整过程 - Java初学者 - ITeye博客