转 更改当前schema

###感谢 
 
更改当前schema 2007-08-24 16:19:04

分类: Oracle

 

在session中,更改当前schema而不重新登陆。

可适用于使用system用户管理其他用户下的数据,而不必在每个表前都加上schema限定词。

[@more@]

在SQL语句中指定对象时,如果不限定对象所在schema,则会使用当前连接用户schema下的对象。通过更改当前session的schema,我们可以在不进行schema限定的情况下,直接引用其他schema下的对象。

尽管public也是oracle中的一个特殊的schema,我们不能将当前schema更改为public。oracle会报告一个错误:ORA-02421: missing or invalid schema authorization identifier

使用system连接,可以运行以下语句来更改当前schema为SCOTT:
alter session set current_schema = 'SCOTT';

但是,此语句并不会更改当前USER。此session的user还是system:
select user from dual;

current_schema切换为了scott:
select sys_context('USERENV', 'CURRENT_SCHEMA') from dual;

当current_schema=scott时,执行的任何操作都相当于是scott在做。只要当前user有权限做这些事情,
则可以在scott用户下创建对象,插入记录,删除记录等。

对于使用system用户进行管理,是很方便的!

如果函数、过程、包在创建时使用了AUTHID CURRENT_USER选,则当其他用户调用此函数、过程、包时,使用current_schema的对象、权限执行。(此特性未亲自验证,只是从手册中和metalink上相关文章中得知。)

posted @ 2020-08-03 14:46  feiyun8616  阅读(333)  评论(0编辑  收藏  举报