# Oracle中创建用户和授权

# orache创建用户

CREATE USER USERNAME IDENTIFIED BY PASSWORD
 default tablespace ERP
temporary tablespace TEMP;

创建用户名为: USERNAME, 密码为 PASSWORD 的用户,指定默认表空间为ERP,临时表空间为TEMP

# 分配权限

GRANT CONNECT TO USERNAME;  --授权普通用户
GRANT RESOURCE  TO USERNAME;  --授权开发人员
GRANT DBA TO USERNAME; --授予DBA权限
GRANT UNLIMITED TABLESPACE TO USERNAME;--授予不限制的表空间
GRANT SELECT ANY TABLE TO USERNAME; --授予查询任何表
GRANT SELECT ANY DICTIONARY TO USERNAME;--授予 查询 任何字典    

# 常用查询

1.查看所有用户:

select * from dba_users;
select * from all_users;
select * from user_users;

2.查看用户或角色系统权限(直接赋值给用户或角色的系统权限):

select * from dba_sys_privs;
select * from user_sys_privs;

3.查看角色(只能查看登陆用户拥有的角色)所包含的权限:

sql>select * from role_sys_privs;

4.查看用户对象权限:

select * from dba_tab_privs;
select * from all_tab_privs;
select * from user_tab_privs;

5.查看所有角色:

select * from dba_roles;

6.查看用户或角色所拥有的角色:

select * from dba_role_privs;
select * from user_role_privs;

7.查看哪些用户有sysdba或sysoper系统权限(查询时需要相应权限):

select * from V$PWFILE_USERS

8.SqlPlus中查看一个用户所拥有权限:

SQL>select * from dba_sys_privs where grantee='username';

9.Oracle删除指定用户所有表的方法:

select 'Drop table '||table_name||';' from all_tables
where owner='要删除的用户名(注意要大写)';

10.删除用户:

drop user user_name cascade;

11.查询当前用户下所有的表:

select table_name from user_tables;

12.删除用户下所有的表数据:

select 'truncate table  ' || table_name from user_tables;