本篇內(nèi)容主要講解“Oracle中重新編譯無(wú)效的存儲(chǔ)過(guò)程是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Oracle中重新編譯無(wú)效的存儲(chǔ)過(guò)程是什么”吧!
成都創(chuàng)新互聯(lián)公司主營(yíng)金牛網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都APP應(yīng)用開(kāi)發(fā),金牛h5微信小程序開(kāi)發(fā)搭建,金牛網(wǎng)站營(yíng)銷(xiāo)推廣歡迎金牛等地區(qū)企業(yè)咨詢(xún)
Oracle 中的存儲(chǔ)過(guò)程在有些情況下會(huì)變成失效狀態(tài),在 PL/SQL Developer 中該存儲(chǔ)過(guò)程的圖標(biāo)左上角顯示一把小紅叉叉。比如儲(chǔ)過(guò)程所引用的對(duì)象失效,dblink 出問(wèn)題啦都可能引起用到它的存儲(chǔ)過(guò)程失效。再就我的存儲(chǔ)過(guò)程經(jīng)常會(huì)變成無(wú)效,至今原因都未查明。
查詢(xún) dba_dependencies 視圖可以看到存儲(chǔ)過(guò)程所引用的對(duì)象,再就在 dba_objects 視圖中可以看到對(duì)象的 created 和 last_ddl_time 時(shí)間。
上面的那種無(wú)效的存儲(chǔ)程,只要不是語(yǔ)法上有問(wèn)題,重新編譯一下又是可用的了??偛荒苊看伟l(fā)現(xiàn)時(shí)人工去編譯的,所以要實(shí)現(xiàn)自動(dòng)化,有以下兩種方法(網(wǎng)上找到的所有的 在Oracle中重新編譯所有無(wú)效的存儲(chǔ)過(guò)程 代碼排版都很混亂,所以主要是重新整理了):
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;
寫(xiě)成一個(gè)存儲(chǔ)過(guò)程 – 讓這個(gè)存儲(chǔ)過(guò)程在某個(gè)時(shí)機(jī)執(zhí)行,比如 Job 中,代碼如下:
create or replace procedure compile_invalid_procedures(
p_owner varchar2 -- 所有者名稱(chēng),即 SCHEMA
) as
--編譯某個(gè)用戶(hù)下的無(wú)效存儲(chǔ)過(guò)程
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ǔ)過(guò)程,依次推及到,重新編譯 FUNCTION、PACKAGE、TYPE、TRIGGER 等,和重建 INDEX 等。 所不同的就是查詢(xún) all_objects 時(shí)的 object_type 不一樣,還有要執(zhí)行的 alter 語(yǔ)句不一樣。
object_type 有哪些可用 select distinct object_type from all_objects 獲取到;alter 的語(yǔ)句寫(xiě)法參考下面:
alter function function_name compile; alter package package)name compile; alter type type_name compile; alter index index_name rebuild;
補(bǔ)充 1. 其實(shí)存儲(chǔ)過(guò)程、函數(shù)等是 INVALID,只要內(nèi)容無(wú)錯(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ǔ)過(guò)程具體錯(cuò)誤 3. 可以用 Oracle 提供的工具:dbms_utility.compile_schema(schema varchar2, compile_all boolean default TRUE); 來(lái)編譯某個(gè) Schema 下的所有 PROCEDURE、FUNCTION、PACKAGE 和 TRIGGER。比如執(zhí)行 dbms_utility.compile_schema(‘Unmi’)。
到此,相信大家對(duì)“Oracle中重新編譯無(wú)效的存儲(chǔ)過(guò)程是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!
網(wǎng)站標(biāo)題:Oracle中重新編譯無(wú)效的存儲(chǔ)過(guò)程是什么
網(wǎng)站鏈接:http://jinyejixie.com/article26/ipegjg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、網(wǎng)站建設(shè)、標(biāo)簽優(yōu)化、品牌網(wǎng)站建設(shè)、商城網(wǎng)站、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
營(yíng)銷(xiāo)型網(wǎng)站建設(shè)知識(shí)