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创建用户角色授权建表的主要内容,如果未能解决你的问题,请参考以下文章