300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 关于Oracle存储过程执行权限问题的解决

关于Oracle存储过程执行权限问题的解决

时间:2018-09-29 07:30:53

相关推荐

关于Oracle存储过程执行权限问题的解决

数据库|mysql教程

oracle数据库教程,关于Oracle存储过程执行权限问题

数据库-mysql教程

管理系统登录页面源码,vscode中输入变量,ubuntu修复专家,nginx端口转发tomcat,sqlite建立多个数据表,爬虫淘宝前三页的价格和名称,php 输出csv,seo推广公司报价价格,网站后台登录地址修改,discuz 模板 手册lzw

在数据库系统中存储过程是必不可少的利器,存储过程是预先编译好的为实现一个复杂功能的一段Sql语句集合。它的优点我就不多说了,

盗号源码,在vscode写汇编语言,mstsc ubuntu,tomcat视频教学,sqlite如何查找,网页设计的结构,如何删除域服务器,swift 瀑布流插件,dhtmlx 前端框架,爬虫有错吗,getenv php,seo工作难吗,springboot授权模式,鞋子批发网站源码,css3 触屏 模拟网页端hover效果,轻松筹方案模板,高端后台,响应式页面copy,如何搭建禅道管理系统,情侣博客程序lzw

ftp程序源码,下载vscode之前,nano ubuntu,增加tomcat服务,qt sqlite编辑器,wordpress 置顶 插件,前端要求公司购买框架开发,网络爬虫技术工作原理,php 数组 sql,徐州seo排名技术,网站首页广告代码,苹果手机网页特效,图片模板软件lzw

在数据库系统中存储过程是必不可少的利器,存储过程是预先编译好的为实现一个复杂功能的一段Sql语句集合。它的优点我就不多说了,,说一下我碰到的问题吧。我在项目开发的过程中需要用存储过程来实现一个功能,其中涉及到判断一张表是否已经建立,没有建立就由存储过程来建立这张表。

写这段存储过程比较简单,在测试执行的过程中,系统出现如下提示:

从错误提示我们定位到错误,发现存储过程在执行 Create table语句时,权限不足。我尝试着把存储过程改成匿名存储过程在PL/SQL中执行,语句既然通过了。这说明这段语句没有问题,问题出现在执行存储过程中。我使用的是DBA帐号登录系统,按理应该不存在权限不足的问题呀。问题出现再哪里呢?通过上网查阅资料,发现Oracle对于执行存储过程有和Sql-Server不一样的规定,这个规定造成了执行建表语句权限不足。

Oracle规定,在默认的情况下,在调用存储过程用户的角色不起作用,即在执行存储过程时只有Public权限。所以在调用Create table时,会有权限不足的提示。

存储过程分为两种,即DR(Definer’s Rights ) Procedure和IR(Invoker’s Rights ) Procedure。为什么会有两种存储过程呢?其实考虑完下面的问题就清楚了。比如说用户hrch创建了删除表tar_table的存储过程drop_table(),当用户hrch调用时,即删除用户hrch下的表tar_table;如果是另一个用户scott调用呢?是删除用户scott下的tar_table表呢,还是删除用户hrch下的tar_table呢?另外,如果存储过程中包含建表语句,不管是用户hrch还是用户scott调用都会失败,因为Public没有建表权限,除非为Public grant建表权限。所以,存储过程的调用者会面临两个问题:

存储过程的名称解析环境

存储过程的执行权限

这两个问题可以在定义存储过程时,通过指定AUTHID 属性,即定义DR Procedure 和IR Procedure来解决。

DR Procedure

1、定 义

CREATE OR REPLACE procedure DEMO(ID in NUMBER) AUTHID DEFINER as

BEGIN

END DEMO;

2、名称解析环境为定义该存储过程的用户所在的Schema。

3、执行该存储过程时只有Public权限。

IR Procedure

1、定 义

CREATE OR REPLACE procedure DEMO(ID in NUMBER) AUTHID CURRENT_USER as

BEGIN

END DEMO;

2、名称解析环境为调用该存储过程的用户所在的Schema。

3、执行该存储过程时拥有调用者的所有权限,即调用者的Role是有效的。

我们碰到的问题只需要使用IR Procedure就能很快解决问题啦,我把代码修改为如下:

执行存储过程,顺利通过。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。