Oracle預存程序ORA-00942: 表或視圖不存在問題解決

來源:互聯網
上載者:User
今天在寫預存程序的時候,發現一個很詭異的問題,預存程序裡就一個最簡單的SELECT動態SQL語句。編寫完成以後,執行這個預存程序,總是提示ORA-00942: table or view does not exist(ERROR -942 ORA-00942: 表或視圖不存在)這個錯誤,但是我將這個SQL語句複製出來,單獨在命令列運行,而又沒有任何錯誤。很糾結,很納悶,很無解,好好的一個SELECT語句,在命令列裡就可以執行,放到預存程序就會出錯了,怎麼就不對了。

後來經過Google,分析和總結,最終找到了答案。為了滿足有的讀者就是為了找到解決問題的答案,而並不需要接下來長篇大論的分析,我這裡就先給出答案。

角色在函數、預存程序、觸發器中都是失效的,也就是說,使用者從角色繼承過來的許可權,不能在函數、預存程序、觸發器中使用。在函數、預存程序、觸發器中,如果要訪問其他使用者的對象,需要顯式地給使用者授予訪問的許可權。

上面也說了,由於對使用者jelly2賦予的是DBA角色,而角色許可權在預存程序中是失效的,所以,為了防止存取權限失效,我們需要顯示的對jelly2使用者賦予訪問jelly.tb_student表的許可權。

grant select any table to jelly2;
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.