溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2021-11-09 14:18:49 來源:億速云 閱讀:259 作者:iii 欄目:關(guān)系型數(shù)據(jù)庫(kù)

本篇內(nèi)容主要講解“Oracle中重新編譯無效的存儲(chǔ)過程是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Oracle中重新編譯無效的存儲(chǔ)過程是什么”吧!

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

查詢 dba_dependencies 視圖可以看到存儲(chǔ)過程所引用的對(duì)象,再就在 dba_objects 視圖中可以看到對(duì)象的 created 和 last_ddl_time 時(shí)間。

上面的那種無效的存儲(chǔ)程,只要不是語法上有問題,重新編譯一下又是可用的了??偛荒苊看伟l(fā)現(xiàn)時(shí)人工去編譯的,所以要實(shí)現(xiàn)自動(dòng)化,有以下兩種方法(網(wǎng)上找到的所有的 在Oracle中重新編譯所有無效的存儲(chǔ)過程 代碼排版都很混亂,所以主要是重新整理了):

Oracle SQL *Plus 中 – 用 spool 生成腳本文件,然后 @ 調(diào)入執(zhí)行,代碼如下:

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;

  1. 寫成一個(gè)存儲(chǔ)過程 – 讓這個(gè)存儲(chǔ)過程在某個(gè)時(shí)機(jī)執(zhí)行,比如  Job 中,代碼如下:


  2. create or replace procedure compile_invalid_procedures(

  3.     p_owner varchar2 -- 所有者名稱,即 SCHEMA

  4. ) as

  5. --編譯某個(gè)用戶下的無效存儲(chǔ)過程

  6.     str_sql varchar2(200);

  7. begin

  8.     for invalid_procedures in (select object_name from all_objects

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

  10.     loop

  11.         str_sql := 'alter procedure ' ||invalid_procedures.object_name || ' compile';

  12.         begin

  13.             execute immediate str_sql;

  14.         exception

  15.           --When Others Then Null;

  16.             when OTHERS Then

  17.                dbms_output.put_line(sqlerrm);

  18.         end;

  19.     end loop;

  20. end;

這里述及的是如何重新編譯存儲(chǔ)過程,依次推及到,重新編譯 FUNCTION、PACKAGE、TYPE、TRIGGER 等,和重建 INDEX 等。
所不同的就是查詢 all_objects 時(shí)的  object_type 不一樣,還有要執(zhí)行的 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;
補(bǔ)充 
  1. 其實(shí)存儲(chǔ)過程、函數(shù)等是 INVALID,只要內(nèi)容無錯(cuò)誤就不要緊,因?yàn)閳?zhí)行的時(shí)候會(huì)自動(dòng)重新編譯 
  2. 在 SQL *Plus 或者 PL/SQL Developer 的 Command Windows 中用 show  errors  procedure  procedure_name 
  或 show errors function function_name 可以查看到存儲(chǔ)過程具體錯(cuò)誤 
  3. 可以用 Oracle 提供的工具:dbms_utility.compile_schema(schema varchar2, compile_all boolean default TRUE); 
  來編譯某個(gè) Schema 下的所有 PROCEDURE、FUNCTION、PACKAGE 和 TRIGGER。比如執(zhí)行 dbms_utility.compile_schema(‘Unmi’)。

到此,相信大家對(duì)“Oracle中重新編譯無效的存儲(chǔ)過程是什么”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI