Oracle使用实例:创建只读用户
2017-08-04 19:02
330 查看
场景:数据库dbtest(服务名)下,创建reader只读用户访问查询scott普通用户下的表及数据
这里先只介绍使用命令操作的一种方法
1. 管理员权限登陆sqlplus
打开cmd,登陆方法命令很多,例如:
或者 sqlplus / as sysdba 之类命令进入sqlplus
然后conn scott/tiger@dbtest as sysdba
2. 创建一个新用户reader,密码123456
3. 为reader用户赋权限
4. 为reader用户赋查询表权限
为查询指定表”table1”赋权
为查询所有表赋权
下面的sql语句是用来生成批量执行语句的,生成的语句全部执行后即可完成对reader进行所有表查询权限的赋权
5. 为reader创建同义词
前面已经为reader用户赋了创建同义词的权限,可以登陆reader用户直接创建,当然也可以在管理员用户下创建;如果不创建同义词,那么reader用户查询表时,必须使用scott.table1这类的写法
为指定表”table1”创建同义词
为所有表创建同义词
下面的sql语句是用来生成批量执行语句的,生成的语句全部执行后即可完成对所有表创建同义词,由于这里用到管理员权限才能查询到的内容,因此执行这个需要管理员权限
5. 测试reader只读权限
接下来就可以使用sql进行reader用户的操作了
这里先只介绍使用命令操作的一种方法
1. 管理员权限登陆sqlplus
打开cmd,登陆方法命令很多,例如:
sqlplus scott/tiger@dbtest as sysdba
或者 sqlplus / as sysdba 之类命令进入sqlplus
然后conn scott/tiger@dbtest as sysdba
2. 创建一个新用户reader,密码123456
create user reader identified by 123456;
3. 为reader用户赋权限
/** 连接权限 */ grant connect to reader; /** 创建同义词权限 */ grant create synonym to reader;
4. 为reader用户赋查询表权限
为查询指定表”table1”赋权
grant select on scott.table1 to reader;
为查询所有表赋权
下面的sql语句是用来生成批量执行语句的,生成的语句全部执行后即可完成对reader进行所有表查询权限的赋权
select 'grant select on '||owner||'.'||object_name||' to reader;' from dba_objects where owner in ('SCOTT') and object_type='TABLE';
5. 为reader创建同义词
前面已经为reader用户赋了创建同义词的权限,可以登陆reader用户直接创建,当然也可以在管理员用户下创建;如果不创建同义词,那么reader用户查询表时,必须使用scott.table1这类的写法
为指定表”table1”创建同义词
create or replace synonym reader.table1 for scott.table1;
为所有表创建同义词
下面的sql语句是用来生成批量执行语句的,生成的语句全部执行后即可完成对所有表创建同义词,由于这里用到管理员权限才能查询到的内容,因此执行这个需要管理员权限
select 'create or replace synonym reader.'||object_name||' for '||owner||'.'||object_name||';' from dba_objects where owner in ('SCOTT') and object_type='TABLE';
5. 测试reader只读权限
接下来就可以使用sql进行reader用户的操作了
相关文章推荐
- oracle 创建表用户/空间/临时表空间设置用户默认表空间 为用户授权操作实例
- Oracle中用户a,使用用户b中的表创建视图,报错!ORA-01031: insufficient privileges
- 使用 MyEclipse 插件创建 Hibernate + Struts 连接oracle实例(动画)
- 使用Oracle SQLDeveloper连接数据库并创建用户
- ORACLE创建用户1、使用oracle用户登录系统
- Oracle创建用户及删除用户的实例
- 在oracle中创建只读某几张表权限的用户
- oracle创建只读用户
- Oracle创建用户及删除用户的实例
- Oracle使用SQL脚本创建表空间,用户,分配权限
- 使用Oracle SQLDeveloper连接数据库并创建用户
- ORACLE用户的创建与授只读权
- 安装完Oracle后 使用dbca创建数据库 弹出ORA-01092: ORACLE 实例终止,强制断开连接
- 使用Oracle SQLDeveloper(Oracle 11g)连接数据库并创建用户
- oracle中使用系统用户创建用户以及常见oracle命令
- 常用sql命令@oracle数据类型概括@权限、角色、用户的创建于使用@伪列及其注意事项
- 使用Oracle SQLDeveloper连接数据库并创建用户
- oracle 10g创建只读用户
- 使用Oracle SQLDeveloper连接数据库并创建用户
- 【经验】使用Oracle的SQL Developer创建用户方法