存储过程中调用EXECUTE IMMEDIATE的“权限不足”问题
2011-09-15 10:29
323 查看
存储过程中有一条语句是EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)';当执行该存储过程时,可能会报“ORA-01031: 权限不足”的错误,但直接使用匿名块执行EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)'是成功的。
这是因为默认情况下,数据库对存储过程在编译阶段进行权限检测,数据库检测存储过程的所有者是否拥有直接赋予的权限,而不是通过一个角色等间接赋予的权限。但是在创建存储过程的时候使用了AUTHID CURRENT_USER这个选项,那么语句执行的权限将在执行过程中根据执行者的权限进行判断。
解决的方法有两个:一是直接授权用户DDL权限,二是使用AUTHID CURRENT_USER选项。
create or replace procedure p_test Authid Current_User as begin execute immediate 'create table creat_table(id number)'; end;
这是因为默认情况下,数据库对存储过程在编译阶段进行权限检测,数据库检测存储过程的所有者是否拥有直接赋予的权限,而不是通过一个角色等间接赋予的权限。但是在创建存储过程的时候使用了AUTHID CURRENT_USER这个选项,那么语句执行的权限将在执行过程中根据执行者的权限进行判断。
解决的方法有两个:一是直接授权用户DDL权限,二是使用AUTHID CURRENT_USER选项。
create or replace procedure p_test Authid Current_User as begin execute immediate 'create table creat_table(id number)'; end;
相关文章推荐
- 存储过程中调用EXECUTE IMMEDIATE的“权限不足”问题
- 存储过程中调用EXECUTE IMMEDIATE的“权限不足”问题
- 存储过程中调用EXECUTE IMMEDIATE的“权限不足”问题
- 存储过程中调用EXECUTE IMMEDIATE的“权限不足”
- 存储过程中Create Table权限不足问题
- 跨数据库调用存储过程权限问题
- ORACLE在存储过程中调用dbms_包的权限问题
- Oracle的存储过程中创建临时表报权限不足问题
- mysql 存储过程调用权限消失的问题,恢复权限
- 解决执行存储过程出现权限不足问题(ORA-01031)
- MFC中和libpq调用PostgreSQL存储过程需要注意的问题
- oracle 父存储过程调用子过程的事务问题
- Mysql修改存储过程相关权限问题
- 关于asp调用oracle存储过程的问题
- 程序调用查询数据存储过程的问题
- 解决多线程调用sql存储过程问题
- C#调用存储过程的小问题
- oracle 存储过程给另一个用户的权限问题
- 在存储过程中建立临时表提示权限不足的解决办法
- JDBC调用Sql server 2005 存储过程出现的问题