1. 程式人生 > >Oracle儲存過程ORA-00942: 表或檢視不存在問題解決

Oracle儲存過程ORA-00942: 表或檢視不存在問題解決

今天在寫儲存過程的時候,發現一個很詭異的問題,儲存過程裡就一個最簡單的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;