亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

古蔺县| 牡丹江市| 容城县| 阜南县| 南木林县| 兰溪市| 通榆县| 湘潭市| 石景山区| 家居| 若尔盖县| 姚安县| 北碚区| 慈溪市| 易门县| 武陟县| 沂源县| 鄂州市| 韶山市| 奉化市| 文水县| 德阳市| 利辛县| 察隅县| 辽宁省| 鄂伦春自治旗| 石门县| 安西县| 庄浪县| 湾仔区| 汾阳市| 庆城县| 万州区| 明星| 探索| 平邑县| 三河市| 托克逊县| 桂平市| 天等县| 锦州市|