ORA-06512 问题解决是怎样的呢
发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,这期内容当中小编将会给大家带来有关ORA-06512 问题解决是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。在执行存储过程时,有动态执行SQL时,有时报错O
千家信息网最后更新 2024年09月21日ORA-06512 问题解决是怎样的呢
SQL> select * from dba_role_privs where grantee='dev'; GRANTEE GRANTED_ROLE ADMIN_OPTION DEFAULT_ROLE ------------ ------------ ------------ ------------ DEV CONNECT NO YES DEV RESOURCE NO YES --再创建一个测试存储过程: create or replace procedure p_create_table is begin Execute Immediate 'create table test(id int)'; end p_create_table; --然后测试 SQL> exec p_create_table; begin p_create_table; end; ORA-01031: 权限不足 ORA-06512: 在"DEV.P_CREATE_TABLE", line 3 ORA-06512: 在line 1 --可以看到,即使拥有CONNECT,RESOURCE role,也不能创建表。role在存储过程中不可用。 --遇到这种情况,我们一般需要显式进行系统权限,如grant create table to DEV; --但这种方法太麻烦,有时候可能需要进行非常多的授权才能执行存储过程 --实际上,oracle给我们提供了在存储过程中使用role权限的方法: --修改存储过程,加入Authid Current_User时存储过程可以使用role权限。 create or replace procedure p_create_table Authid Current_User is begin Execute Immediate 'create table test(id int)'; end p_create_table; --再尝试执行: SQL> exec p_create_table; PL/SQL procedure successfully completed --已经可以执行了。
这期内容当中小编将会给大家带来有关ORA-06512 问题解决是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
在执行存储过程时,有动态执行SQL时,有时报错ORA-06512。SQL> select * from dba_role_privs where grantee='dev'; GRANTEE GRANTED_ROLE ADMIN_OPTION DEFAULT_ROLE ------------ ------------ ------------ ------------ DEV CONNECT NO YES DEV RESOURCE NO YES --再创建一个测试存储过程: create or replace procedure p_create_table is begin Execute Immediate 'create table test(id int)'; end p_create_table; --然后测试 SQL> exec p_create_table; begin p_create_table; end; ORA-01031: 权限不足 ORA-06512: 在"DEV.P_CREATE_TABLE", line 3 ORA-06512: 在line 1 --可以看到,即使拥有CONNECT,RESOURCE role,也不能创建表。role在存储过程中不可用。 --遇到这种情况,我们一般需要显式进行系统权限,如grant create table to DEV; --但这种方法太麻烦,有时候可能需要进行非常多的授权才能执行存储过程 --实际上,oracle给我们提供了在存储过程中使用role权限的方法: --修改存储过程,加入Authid Current_User时存储过程可以使用role权限。 create or replace procedure p_create_table Authid Current_User is begin Execute Immediate 'create table test(id int)'; end p_create_table; --再尝试执行: SQL> exec p_create_table; PL/SQL procedure successfully completed --已经可以执行了。
上述就是小编为大家分享的ORA-06512 问题解决是怎样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
过程
存储
权限
问题
内容
方法
分析
测试
专业
中小
内容丰富
动态
实际
实际上
就是
情况
文章
时报
更多
有时候
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
比较小的软件开发公司
网络安全与健康讲座短信
大宇宙软件开发面试笔试题
手机无线网络安全性怎么设置
网络安全行业会议
机顶盒认证服务器
炼金术士视频软件开发
删除两个数据库语句
梦幻2019开服务器列表
河南亿恩网络技术有限公司
吴迪软件开发
鹏博士网络技术
广州定制软件开发服务费
数字金融网络安全股
维护网络安全讲座感受
登录服务器失败请检查防火墙设置
玩csgo选什么服务器
服务器月度巡检模板
饥荒联机版怎么调整服务器人数
数据库安全性级别有几级
同服务器连接
数据库原理与应用中国水利
数据库范式最简单的解释
二青会网络安全保障方案
猎头者软件开发
数据库转移表到另一个模式
河南小石头软件开发
金蝶要用数据库么
浙江新品服务器厂家直供
北京二手服务器回收