久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

Oracle中重新編譯無效的存儲過程是什么

195次閱讀
沒有評論

共計 1990 個字符,預計需要花費 5 分鐘才能閱讀完成。

本篇內容主要講解“Oracle 中重新編譯無效的存儲過程是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓丸趣 TV 小編來帶大家學習“Oracle 中重新編譯無效的存儲過程是什么”吧!

Oracle 中的存儲過程在有些情況下會變成失效狀態,在 PL/SQL Developer 中該存儲過程的圖標左上角顯示一把小紅叉叉。比如儲過程所引用的對象失效,dblink 出問題啦都可能引起用到它的存儲過程失效。再就我的存儲過程經常會變成無效,至今原因都未查明。

查詢 dba_dependencies 視圖可以看到存儲過程所引用的對象,再就在 dba_objects 視圖中可以看到對象的 created 和 last_ddl_time 時間。

上面的那種無效的存儲程,只要不是語法上有問題,重新編譯一下又是可用的了。總不能每次發現時人工去編譯的,所以要實現自動化,有以下兩種方法 (網上找到的所有的 在 Oracle 中重新編譯所有無效的存儲過程 代碼排版都很混亂,所以主要是重新整理了):

Oracle SQL *Plus 中 – 用 spool 生成腳本文件,然后 @ 調入執行,代碼如下:

spool ExecCompProc.sql

select alter procedure ||object_name|| compile; from all_objects

where status = INVALID and object_type = PROCEDURE AND owner= UNMI  

spool off

@ExecCompProc.sql;

寫成一個存儲過程 – 讓這個存儲過程在某個時機執行,比如  Job 中,代碼如下:

create or replace procedure compile_invalid_procedures(

    p_owner varchar2 — 所有者名稱,即 SCHEMA

) as

– 編譯某個用戶下的無效存儲過程

    str_sql varchar2(200);

begin

    for invalid_procedures in (select object_name from all_objects

       where status = INVALID and object_type = PROCEDURE and owner=upper(p_owner))

    loop

        str_sql := alter procedure ||invalid_procedures.object_name || compile

        begin

            execute immediate str_sql;

        exception

          –When Others Then Null;

            when OTHERS Then

               dbms_output.put_line(sqlerrm);

        end;

    end loop;

end;

 這里述及的是如何重新編譯存儲過程,依次推及到,重新編譯  FUNCTION、PACKAGE、TYPE、TRIGGER  等,和重建  INDEX  等。所不同的就是查詢  all_objects  時的  object_type  不一樣,還有要執行的  alter  語句不一樣。

object_type 有哪些可用 select distinct object_type from all_objects 獲取到;alter 的語句寫法參考下面:

alter function function_name compile;
alter package package)name compile;
alter type type_name compile;
alter index index_name rebuild;
 補充  
 1.  其實存儲過程、函數等是  INVALID,只要內容無錯誤就不要緊,因為執行的時候會自動重新編譯  
 2.  在  SQL *Plus  或者  PL/SQL Developer  的  Command Windows  中用  show errors procedure procedure_name 
  或  show errors function function_name  可以查看到存儲過程具體錯誤  
 3.  可以用  Oracle  提供的工具:dbms_utility.compile_schema(schema varchar2, compile_all boolean default TRUE); 
  來編譯某個  Schema  下的所有  PROCEDURE、FUNCTION、PACKAGE  和  TRIGGER。比如執行  dbms_utility.compile_schema(‘Unmi’)。

到此,相信大家對“Oracle 中重新編譯無效的存儲過程是什么”有了更深的了解,不妨來實際操作一番吧!這里是丸趣 TV 網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-24發表,共計1990字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 桐柏县| 昌黎县| 五河县| 常熟市| 罗城| 鹿泉市| 侯马市| 惠来县| 老河口市| 长春市| 吴旗县| 休宁县| 龙陵县| 孟津县| 天柱县| 河西区| 华容县| 台中县| 吕梁市| 吉安县| 汉川市| 洛川县| 维西| 庆安县| 瓦房店市| 长丰县| 灵璧县| 上饶市| 德清县| 海阳市| 辽宁省| 阿拉善右旗| 馆陶县| 弥渡县| 阿合奇县| 盐池县| 郓城县| 杭州市| 灵武市| 安远县| 阿合奇县|