日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Oracle之AUTHID CURRENT_USER

發布時間:2024/8/26 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Oracle之AUTHID CURRENT_USER 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

沒有AUTHID CURRENT_USER表示定義者權限(definer rights),以定義者身份執行;

加上AUTHID CURRENT_USER表示調用者權限(invoker rights),以調用者身份執行。

?

例:

?

1. 創建兩個用戶:xxpo,xxgl

2. 在xxpo下創建一張表:xxpo_authid_test

[c-sharp]?view plaincopy
  • CREATE?TABLE?xxpo.xxpo_authid_test(ID?NUMBER,NAME?VARCHAR2(20));??
  • 3. 在xxpo下創建如下兩個procedure

    3.1 xxpo_no_authid_test_prc:

    [c-sharp]?view plaincopy
  • CREATE?OR?REPLACE?PROCEDURE?xxpo_no_authid_test_prc??
  • (??
  • ??p_id???IN?NUMBER??
  • ?,p_name?IN?VARCHAR2??
  • )?IS??
  • BEGIN??
  • ??INSERT?INTO?xxpo_authid_test??
  • ????(id??
  • ????,NAME)??
  • ??VALUES??
  • ????(p_id??
  • ????,p_name);??
  • END?xxpo_no_authid_test_prc;??
  • 3.2 xxpo_has_authid_test_prc:

    [c-sharp]?view plaincopy
  • CREATE?OR?REPLACE?PROCEDURE?xxpo_has_authid_test_prc??
  • (??
  • ??p_id???IN?NUMBER??
  • ?,p_name?IN?VARCHAR2??
  • )?AUTHID?CURRENT_USER?IS??
  • BEGIN??
  • ??INSERT?INTO?xxpo_authid_test??
  • ????(id??
  • ????,NAME)??
  • ??VALUES??
  • ????(p_id??
  • ????,p_name);??
  • END?xxpo_has_authid_test_prc;??
  • 4. 將兩個procedure的執行權限(EXECUTE)賦予xxgl:

    [c-sharp]?view plaincopy
  • SQL>?GRANT?EXECUTE?ON?xxpo_no_authid_test_prc?TO?xxgl;??
  • ???
  • Grant?succeeded??
  • SQL>?GRANT?EXECUTE?ON?xxpo_has_authid_test_prc?TO?xxgl;??
  • ???
  • Grant?succeeded??
  • 5. 在xxgl分別調用xxpo下面的兩個procedure,查看結果:

    [c-sharp]?view plaincopy
  • SQL>?BEGIN??
  • ??2??xxpo.xxpo_no_authid_test_prc(1,'nameXXGL001');??
  • ??3??END;??
  • ??4??/??
  • ???
  • PL/SQL?procedure?successfully?completed??
  • ???
  • SQL>???
  • SQL>?BEGIN??
  • ??2??xxpo.xxpo_has_authid_test_prc(2,'nameXXGL002');??
  • ??3??END;??
  • ??4??/??
  • ???
  • BEGIN??
  • xxpo.xxpo_has_authid_test_prc(2,'nameXXGL002');??
  • END;??
  • ???
  • ORA-00942:?table?or?view?does?not?exist??
  • ORA-06512:?at?"XXPO.XXPO_HAS_AUTHID_TEST_PRC",?line?7??
  • ORA-06512:?at?line?3??
  • ???
  • SQL>?SELECT?*?FROM?xxpo.xxpo_authid_test;??
  • ???
  • ????????ID?NAME??
  • ----------?--------------------??
  • ?????????1?nameXXGL001??
  • ???
  • SQL>???
  • 由于我們并沒有在xxgl用戶下創建一個名為xxpo_authid_test的表,所以當我們在xxgl用戶下以調用者(xxgl)權限去執行xxpo.xxpo_has_authid_test_prc這個procedure的時候,會報表不能找到(ORA-00942)的錯誤;而以定義者(xxpo)權限去執行則不存在此問題。


    ---

    Authid Current_User 是調用者權限。 oracle DB下面有2種執行的權限:定義者權限和調用者權限。 默認都是定義者權限。聲明Authid Current_User后就是調用者權限。定義者權限的現象是,如果在APPS下創建的procedure,那其他user,只要能執行procedure,都是以apps的名義來執行的。因為APPS是procedure的定義者。 APPS能做什么,那這個procedure就能做什么。調用者權限的現象是,如果在APPS下創建的procedure,如果其他user有權限執行這個procedure,這個procedure所做的內容都是以當前user的名義來做的。如果某個table,只有APPS才有權限修改,那這個procedure在apps下面才執行成功。其他user下是不成功的。

    總結

    以上是生活随笔為你收集整理的Oracle之AUTHID CURRENT_USER的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。