存储过程中调用EXECUTE IMMEDIATE的“权限不足”
发布时间:2020-12-12 15:18:06 所属栏目:百科 来源:网络整理
导读:EXECUTE IMMEDIATE是Oracle中使用动态SQL的一种方法,可以直接执行,也可以在存储过程中调用。然而在存储过程中调用可能会遇到权限不足的问题,如在存储过程中执行重建索引语句: sqlt := 'alter index ' || idx.index_name || ' rebuild online '; EXECUTE
EXECUTE IMMEDIATE是Oracle中使用动态SQL的一种方法,可以直接执行,也可以在存储过程中调用。然而在存储过程中调用可能会遇到权限不足的问题,如在存储过程中执行重建索引语句: sqlt := 'alter index ' || idx.index_name || ' rebuild online '; EXECUTE IMMEDIATE sqlt; 会报权限不足:如下 ORA-01031: 权限不足 既然提示说权限不足,所以问题的解决方法就是要赋予用户scott Create Any Table的权限,以SYS登录,然后执行: GRANT CREATE ANY TABLE TO SCOTT 再重新执行下刚才的存储过程,成功。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |