存储过程执行权限

最后更新时间: 2014年4月13日,星期日


存储过程分为两种,即DR(Definer's Rights ) Procedure和IR(Invoker's Rights ) Procedure。为什么会有两种存储过程呢?比如说用户user02创建了修改表t1的存储过程,当用户user01调用时,是修改的user01自己的t1表还是user02的t1表?  

示例:
用户user02将存过赋执行权限给user01:
grant execute on user02.prc1 to user01;
grant execute on user02.prc2 to user01;
grant execute on user02.prc3 to user01;


用户user01执行user02下的存过 prc1,prc2,prc3;
用户user01只有执行user02下存过的权限,没有查询/修改user02.t1的任何权限;
--默认是 authid DEFINER
create or replace procedure prc1 is
v_sql varchar2(200);
begin 
begin 
v_sql :='drop table t1 purge';
EXECUTE IMMEDIATE v_sql;
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
exception when others then
dbms_output.put_line('表不存在!');
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
end;
for i in 1 .. 10
loop
insert into t1 values(0);
end loop;
commit;
end;
/
-- DEFINER 表示使用的是定义者的权限,即user02的权限,修改的是 user02.t1表,尽管user01没有直接修改user02.t1表的任何权限
create or replace procedure prc2 authid DEFINER is
v_sql varchar2(200);
begin 
begin 
v_sql :='drop table t1 purge';
EXECUTE IMMEDIATE v_sql;
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
exception when others then
dbms_output.put_line('表不存在!');
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
end;
for i in 1 .. 10
loop
insert into t1 values(2);
end loop;
commit;
end;
/

-- current_user 表示调用者权限,修改的是user01.t1表
create or replace procedure prc3 authid current_user is
v_sql varchar2(200);
begin 
begin 
v_sql :='drop table t1 purge';
EXECUTE IMMEDIATE v_sql;
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
exception when others then
dbms_output.put_line('表不存在!');
v_sql:='create table t1(id int)';
EXECUTE IMMEDIATE v_sql;
end;
for i in 1 .. 10
loop
insert into t1 values(3);
end loop;
commit;
end;
/


参考: 
http://blog.itpub.net/12272958/viewspace-686460/
http://docs.oracle.com/cd/B12037_01/appdev.101/b10807/08_subs.htm#i18574


1. 匿名块(DECLARE BEGIN END;)总是IR Procedure,触发器和视图总是DR Procedure。我们可以通过视图*_PROCEDURES来查看存储过程的AUTHID属性值。
2. 存储过程、包、都适用。


来自为知笔记(Wiz)


转载于:https://www.cnblogs.com/bowshy/p/3661867.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575513.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

架构风格与基于网络的软件架构设计

原文链接 https://blog.csdn.net/on_1y/article/details/60358117 架构风格与基于网络的软件架构设计 如今许多服务都采用了 RESTful API, 而 REST 这一架构风格,最早即来源于 Roy Thomas Fielding 的博士论文 Architectural Styles and the Design of Network-bas…

2009年广东省大学生程序设计竞赛 A

// 水题&#xff0c;数高为 2 就可以 既把2-n 点 都连到 1 点&#xff0c;#include<cstdio>#include<iostream>#include<map>#include <set>#include<cstring>#include<queue>#include<algorithm>#include<vector>using names…

视频容器与编解码器的区别

这基本是一个老生常谈的东西了&#xff0c;但是我仍然是看了很多资料&#xff0c;加上一点点理解才完全明白了其中的差别所在。 这就像上学时的考试大纲&#xff0c;这种东西要求是识记类型的&#xff0c;没有技术门槛&#xff0c;但是只有你把东西都记住之后&#xff0c;才完全…

C#生成高清缩略图

01/// <summary> 02 /// 为图片生成缩略图 03 /// </summary> 04 /// <param name"phyPath">原图片的路径</param> 05 /// <param name"width">缩略图宽</param> 06 /// <param name"height"…

win7安装nodejs 高版本不支持 换低版本

win7安装nodejs失败 显示This application is only supported on Windows 8.1,Windows Server 2012 R2,or higer. win7安装nodejs失败 在win7重装nodejs&#xff0c;版本是node-v14.16.1-x64&#xff0c;安装时报了win7系统不支持的问题 2021年4月8日 —— 目前除了最新的v14大…

[翻译]创建ASP.NET WebApi RESTful 服务(9)

一旦成功的发布API后&#xff0c;使用者将依赖于你所提供的服务。但是变更总是无法避免的&#xff0c;因此谨慎的制定ASP.NET Web API的版本策略就变得非常重要。一般来说&#xff0c;新的功能需要无缝的接入&#xff0c;有时新老版本需要并行&#xff0c;以便给使用者足够的时…

研究生导师一般希望招什么样的研究生?

虽然还不是导师&#xff0c;但也在学校蹲了不少年头了&#xff0c;看着一级级研究生毕业奔赴各方&#xff0c;其实还是蛮有感触的。 各位同学很多在硕士期间回忆并不算好&#xff0c;其实就是从一开始没有搞明白一件事&#xff1a;导师招生为了什么&#xff0c;我们上研又为了什…

动态调用链接库(dll) 续

20141118 最近一周做了一个关于仓库管理&#xff0c;拣货任务分配的模块&#xff0c;其中涉及到刷卡自动打印领取任务的功能点。 技术点&#xff1a; C#调用C、delphi的动态链接库。动态链接库的调用方法不同。效果也不相同。 DLL位置&#xff1a;执行程序根目录下面 例&#x…

读写日志文件

日志为文本文件每列以制表符隔开 行以换行符隔开 本次示例简单实现如下相关功能&#xff1a;1.正写日志文本 最新的日志放后面2.倒写日志文本 最新的日志放前面3.读日志文本内容显示在Label4.读日志文本内容到DataTable 及 筛选后显示在GridView--------------------(以下操作并…

游戏策划试题(1)——摘自牛客网

对于游戏涉及的不多&#xff0c;但是对暴雪在各种经验贴和小道消息上还是有些了解的。涉猎一下 策划游戏之类 的面试知识&#xff0c;横向拓宽知识面&#xff0c;也有助于自己拓宽视野&#xff0c;看看这种游戏文案策划 作为一名运营策划&#xff0c;你觉得可通过哪些途径起到保…

Android Fragment应用实战

现在Fragment的应用真的是越来越广泛了&#xff0c;之前Android在3.0版本加入Fragment的时候&#xff0c;主要是为了解决Android Pad屏幕比较大&#xff0c;空间不能充分利用的问题&#xff0c;但现在即使只是在手机上&#xff0c;也有很多的场景可以运用到Fragment了&#xff…

初识树莓派

初识树莓派这一微型计算机&#xff0c;基本了解概念&#xff0c; 1、树莓派简介 Raspberry Pi(中文名为“树莓派”,简写为RPi&#xff0c;或者 RasPi/RPi)是为学生计算机编程教育而设计&#xff0c;只有信用卡大小的卡片式电脑&#xff0c;其系统基于Linux开发而来的。树莓派由…

ffmpeg抓取rtsp流并保存_详细解析RTSP框架和数据包分析(1)

0.引言 本文主要讲解RTSP框架和抓取RTSP数据包&#xff0c;进行详细分析。可以阅读以下几篇文章&#xff0c;能够帮助你更详细理解。 手把手搭建RTSP流媒体服务器 HLS实战之Wireshark抓包分析 HTTP实战之Wireshark抓包分析 1.RTSP协议简述 RTSP&#xff1a;Real Time Stream…

遍历窗体中所有控件的信息

public void TraverControl(Control Ctl) {   foreach (Control c in Ctl.Controls)  {     label1.Text "\n" "" c.Name "" "\n";     //用于显示窗体中包含的所有的控件名&#xff0c;首先显示的是最外层的控件  …

xshell 软件的窗口一直是置顶 调整为不置顶

突然感觉xshell 软件的窗口一直是置顶状态&#xff0c;点别的软件窗口点不过去&#xff0c; 搜索一下&#xff1a;微信的 alta是截图&#xff0c;和xshell这个冲突了。如果在xshell下按了这个&#xff0c;不知不觉就被置顶了。。。。。MMP 即这个意思&#xff1a; 如果要修改…

Linux下Vim工具常用命令

原文地址&#xff1a; http://www.cnblogs.com/lizhenghn/p/3675011.html 在linux下做开发&#xff0c;甚至是只做管理维护工作&#xff0c;也少不了Vim的使用。作为一个新手&#xff0c;我也是刚刚接触&#xff0c;本节将我日常使用或收集的Vim常用命令记录下来。 当然&#x…

整理加解释:以太网、快速以太网、千兆以太网和万兆以太网分别的概念和区分 大详解

一、以太网是什么 以太网(Ethernet)最早是由Xerox(施乐)公司创建的局域网组网规范&#xff0c;1980年DEC、Intel和Xeox三家公司联合开发了初版Ethernet规范—DIX 1.0&#xff0c;1982年这三家公司又推出了修改版本DIX 2.0&#xff0c;并将其提交给EEE 802工作组&#xff0c;经I…

zoj 1109 Language of FatMouse 解题报告

题目链接&#xff1a;http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId109 题目意思&#xff1a;给出一个mouse-english词典&#xff0c;问对于输入的mouse单词&#xff0c;能否在这个词典里找出对应的english&#xff0c;不能输出“eh” 这里用到map来做&#xf…

测试telnet安装成功 以及如何进入和退出telnet命令模式

telnet装好之后&#xff0c;测试。 输入&#xff1a;telnet www.baidu.com 80 出现如图提示是意思是&#xff1a; 正常连通。 然后 按 ctrl ] 进入telnet客户端命令模式&#xff0c;然后用quit退出。进入linux命令模式。

数据按时间拆开分批处理示例

我现在的问题是有一个大的事实表,已经有数十亿条数据,过来的临时表需要merge进去. 临时表的大小也不确定,可能上十亿也可能只有几百几千万而已. 如果直接让这两个表merge起来,则需要很大的内存来进行处理.所以我就想着把数据进行按时间拆分的处理,然后merge进去, 拆分的条件是如…