您好,登錄后才能下訂單哦!
本篇內(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;
寫成一個(gè)存儲(chǔ)過程 – 讓這個(gè)存儲(chǔ)過程在某個(gè)時(shí)機(jī)執(zhí)行,比如 Job 中,代碼如下:
create or replace procedure compile_invalid_procedures(
p_owner varchar2 -- 所有者名稱,即 SCHEMA
) as
--編譯某個(gè)用戶下的無效存儲(chǔ)過程
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;
這里述及的是如何重新編譯存儲(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í)!
免責(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)容。