存储过程中有一条语句是EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)';当执行该存储过程时,可能会报“ORA-01031: 权限不足”的错误,但直接使用匿名块执行EXECUTE IMMEDIATE 'CREATE TABLE TA (id integer)'是成功的。 这是因为默认情况下,数据库对存储过程在编译阶段进行权限检测,数据库检测存储过程的所有者是否拥有直接赋予的权限,而不是通过一个角色等间接赋予的权限。但是在创建存储过程的时候使用了AUTHID CURRENT_USER这个选项,那么语句执行的权限将在执行过程中根据执行者的权限进行判断。 解决的方法有两个:
一是直接授权用户DDL权限
二是使用AUTHID CURRENT_USER选项。
解决了我上篇博文中提到的问题,经过验证,不过sequence的创建也有同样的授权问题
http://blog.youkuaiyun.com/kongqz/archive/2010/12/15/6078035.aspx