没有AUTHID CURRENT_USER表示定义者权限(definer rights),以定义者身份执行;
加上AUTHID CURRENT_USER表示调用者权限(invoker rights),以调用者身份执行。
下面就以一个例子来说明两者的区别:
1. 创建两个用户:cux,apps
2. 在cux下创建一张表:cux_authid_current_user_table
CREATE TABLE cux.cux_authid_current_user_table(ID NUMBER,NAME VARCHAR2(20));
3. 在cux下创建如下两个procedure
3.1 cux_no_authid_pkg:
CREATE OR REPLACE PROCEDURE cux_no_authid_pkg(p_id IN NUMBER, p_name IN VARCHAR2) IS BEGIN INSERT INTO cux_authid_current_user_table (id, NAME) VALUES (p_id, p_name); END cux_no_authid_pkg;
3.2 cux_has_authid_pkg:
CREATE OR REPLACE PROCEDURE cux_has_authid_pkg(p_id IN NUMBER, p_name IN VARCHAR2) AUTHID CURRENT_USER IS BEGIN INSERT INTO cux_authid_current_user_table (id, NAME) VALUES (p_id, p_name); END cux_has_authid_pkg;
4. 将两个procedure的执行权限(EXECUTE)赋予xxgl:
SQL> GRANT EXECUTE ON cux_no_authid_pkg TO apps; Grant succeeded SQL> GRANT EXECUTE ON cux_has_authid_pkg TO apps; Grant succeeded
5. 在apps下分别调用cux下面的两个procedure,查看结果:
SQL> BEGIN cux.cux_no_authid_pkg(1,'test01'); END; PL/SQL procedure successfully completed SQL> BEGIN cux.cux_has_authid_pkg(2,'test02'); END; ORA-00942: table or view does not exist ORA-06512: at "CUX.CUX_HAS_AUTHID_PKG", line 7 ORA-06512: at line 1
由于我们并没有在apps用户下创建一个名为cux_authid_current_user_table的表,所以当我们在apps用户下以调用者(apps)权限去执行cux.cux_has_authid_pkg这个procedure的时候,会报不能找到(ORA-00942)的错误;而以定义者(cux)权限去执行则不存在此问题。
相关推荐
orale定义者权限与调用者权限介绍,ORACLE AUTHID DEFINER与AUTHID CURRENT_USER介绍
用存储过程创建数据表:创建时注意必须添加authid current_user,如果创建的表已存在,存储过程继续执行,但如不不加此关键语句,存储过程将出现异常,这个语句相当于赋权限。例1创建语句如下: 代码如下:create or ...
Create or Replace Package UTL_FTP AUTHID CURRENT_USER as Type Connection is Record( Connection UTL_TCP.Connection, AccountInfo VarChar2(1000), TransferMethod Char(1), --A: ASCII...
Create or Replace Package UTL_ZIP AUTHID CURRENT_USER as Type File_List is Table of Clob; --文件变成流 Function f_File2Blob( as_SubDir in VarChar2, as_FileName in VarChar2 )Return ...
Oracle新建了一个存储过程,里面包含CREATE和DROP,逐条依据可以执行,但是执行整个存储过程报权限不足的错误。... Authid Current_User IS BEGIN ……; END; 存储过程能够正常执行了!
代码如下:create or replace Function GetInvitationNO...– 需要使用“Current_User”的权限防止无法运行“Execute Immediate”命令 & “PRAGMA AUTONOMOUS_TRANSACTION”自制事务防止DML无法DDL的问题 Totalprev V
这里有一个简短的演示包规范,它演示了PLOC背后的思想: CREATE OR REPLACE PACKAGE demo AUTHID current_user ISc_demo_name CONSTANT VARCHAR2 ( 30 CHAR ) : = ' A demo package for PLOC ' ;/* *Your Leading ...
sql> create user juncky identified by oracle default tablespace users sql> temporary tablespace temp quota 10m on data password expire sql> [account lock|unlock] [profile profilename|default]; ...
四、 pg_authid: pg_authid: pg_authid: pg_authid:pg_authid: 64 五、 pg_auth_members: pg_auth_members: pg_auth_members: pg_auth_members:pg_auth_members: pg_auth_members:pg_auth_members:pg_auth_members:...
快速学习函数创建和练习。 创建函数、存储过程、创建过程、调用存储过程、AUTHID、PRAGMA AUTONOMOUS_TRANSACTION、开发存储过程步骤、删除过程和函数、过程与函数的比较
表名:USER Role Module Authority 字段:userId RoleId ModuleId AuthId userName R_name M_name RoleId RoleId ModuleId
主要介绍了PostgreSQL教程(十五):系统表详解,本文讲解了pg_class、pg_attribute、pg_attrdef、pg_authid、pg_auth_members、pg_constraint、pg_tablespace、pg_namespace、pg_database等表的作用和字段介绍,需要的...
'USER_AUTH_KEY'=>'authId' 示例如下: <?php if(!defined('THINK_PATH')) exit(); return array( // 定义数据库连接信息 'DB_TYPE'=> 'mysql',// 指定数据库是mysql 'DB_HOST'=> 'localhost', 'DB_NAME'=>'...
客户端使用post请求提交user、password给服务端进行登录操作; 服务端校验用户是否合法,如果合法将产生一个唯一的身份标识authId,返回给客户端,客户端将此authId存放本地(如localStorage); 客户端在每次需要...
一、pg_tables: ...pg_authid.rolname 表的所有者的名字。 tablespace name pg_tablespace.spcname 包含表的表空间名字(如果是数据库缺省,则为 NULL)。 hasindexes bool pg_class.relhasindex
用法实例化连接对象并调用其方法: from dizzyapi import JSONAPIConn , XMLAPIConn , APIError# Unauthenticated JSON connection# API results are returned as Python dictionariesjson_conn = JSONAPIConn ()...
twilio_js_google_app_engine 通过Twilio api和带有Google表格和javascript的google app引擎通过无服务器发送自定义SMS的方法这种方法完全是无服务器的。 谷歌应用程序引擎将在云中... 使用来自Twilio API凭据的AuthID
" authId " : " ******** " , " authToken " : " ******** " } 该软件包还支持使用ENV变量而不是设置: PLIVO_AUTH_ID PLIVO_AUTH_TOKEN 更多信息 请参阅此处以获取有关plivo-node的更多信息。 请参阅 API文档。...
查找美国任何地址的最近邻居的最佳方法。 要求 没有外部包。 只记得在使用之前npm install 。 用法 这是一个快速示例: var Neighbors = require('le-neighbors'); var neighbors = new Neighbors(authID, ...