亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-11-09 14:18:49 來源:億速云 閱讀:260 作者:iii 欄目:關系型數據庫

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

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


  2. create or replace procedure compile_invalid_procedures(

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

  4. ) as

  5. --編譯某個用戶下的無效存儲過程

  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;

這里述及的是如何重新編譯存儲過程,依次推及到,重新編譯 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中重新編譯無效的存儲過程是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大邑县| 墨竹工卡县| 监利县| 翼城县| 习水县| 大新县| 富锦市| 嘉善县| 咸阳市| 吉安市| 岐山县| 汤原县| 马山县| 皮山县| 阳谷县| 历史| 阳原县| 双峰县| 西吉县| 瑞昌市| 重庆市| 南城县| 荣成市| 桂阳县| 南岸区| 丰顺县| 崇州市| 孝昌县| 乐安县| 涡阳县| 林甸县| 牙克石市| 二连浩特市| 平昌县| 阳谷县| 霸州市| 元江| 民权县| 平陆县| 资阳市| 石城县|