您好,登錄后才能下訂單哦!
這篇文章主要講解了“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的注意點是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。