91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

AUTHID CURRENT_USER的注意點是什么

發布時間:2021-11-08 15:53:59 來源:億速云 閱讀:191 作者:iii 欄目:關系型數據庫

這篇文章主要講解了“AUTHID CURRENT_USER的注意點是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“AUTHID CURRENT_USER的注意點是什么”吧!

1.在A和B用戶下同時創建如下測試表和數據

A:

create table tb_test(a varchar2(50));

insert into tb_test select 1 from dual;

insert into tb_test select 2 from dual;

insert into tb_test select 3 from dual;

commit;

B:

create table tb_test(a varchar2(50));

insert into tb_test select 1 from dual;

insert into tb_test select 2 from dual;

insert into tb_test select 3 from dual;

commit;

2.在A下創建存儲過程并授權給B,注意這里的AUTHID CURRENT_USER

CREATE OR REPLACE PROCEDURE pd_test

AUTHID CURRENT_USER

IS

BEGIN

  UPDATE tb_test SET a = 'abc';

  COMMIT;

END pd_test;

GRANT EXECUTE ON pd_test to B;

3.在用戶B下去執行pd_test時,會發現B用戶下的tb_test表數據被更新成abc,而A用戶下的tb_test數據表未被更新

如果不加AUTHID CURRENT_USER,則A用戶下的tb_test表數據被更新成abc,而B用戶下的tb_test數據表未被更新

關于AUTHID CURRENT_USER的解釋:

這是典型的,數據庫中只創建一個存儲過程,所有用戶都可以使用,但是每個用戶使用的時候只是用自己的權限權限執行,oracle自己的包很多都這樣的。 

存儲過程默認是用定義者definer的身份調用的,如果加上AUTHID CURRENT_USER,則用當前登陸的用戶權限調用,如果該過程的調用者(而非定義者)被授與系統權限execute any procedure或是被該過程的定義者grant execute on授權的話,不用這個AUTHID CURRENT_USER子句,調用者照樣可以使用這個過程。

另外,在Oracle的存儲過程中,如果涉及到操作不同schema下的對象的時候,可以在不同的schema下寫相同的procedure,但這樣帶來的問題是維護和同步帶來了麻煩。

在procedure中加上authid current_user,來說明procedure中操作的對象是當前連接用戶的對象而并不是procedure所屬用戶下的對象。所以在procedure中的DML語句也是在當前連接用戶的對象去操作。

感謝各位的閱讀,以上就是“AUTHID CURRENT_USER的注意點是什么”的內容了,經過本文的學習后,相信大家對AUTHID CURRENT_USER的注意點是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

扎囊县| 阳谷县| 沁阳市| 寿光市| 丹寨县| 大同市| 合川市| 黄大仙区| 德江县| 永仁县| 博野县| 平泉县| 永平县| 双牌县| 五寨县| 麟游县| 舞阳县| 焉耆| 雷山县| 瑞金市| 芷江| 绥化市| 宣汉县| 汾西县| 望江县| 南投市| 辛集市| 浦江县| 开江县| 桂林市| 蓝田县| 平武县| 株洲县| 萨嘎县| 精河县| 正蓝旗| 九寨沟县| 靖西县| 凌源市| 固安县| 区。|