成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

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

本篇內(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;

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

  2. create or replace procedure compile_invalid_procedures(

  3.     p_owner varchar2 -- 所有者名稱(chēng),即 SCHEMA

  4. ) as

  5. --編譯某個(gè)用戶(hù)下的無(wú)效存儲(chǔ)過(guò)程

  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ǔ)過(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)

h5響應(yīng)式網(wǎng)站建設(shè)
洱源县| 航空| 桃园市| 新竹市| 乌拉特前旗| 永修县| 商南县| 盐山县| 东港市| 东源县| 夏津县| 封丘县| 济宁市| 赤水市| 繁昌县| 日照市| 垣曲县| 遵化市| 湖南省| 城口县| 博白县| 丰顺县| 阜新市| 和田县| 哈尔滨市| 嫩江县| 南宁市| 海安县| 罗平县| 巴彦淖尔市| 翁牛特旗| 百色市| 龙胜| 庆元县| 惠州市| 福海县| 岳普湖县| 望江县| 石首市| 奎屯市| 秀山|