天天看點

oracle exec編譯失效,編譯oracle失效的函數、存儲過程、視圖等

進行oracle開發時常常為不時失效的存儲過程,函數等苦惱,于是下決心解決這個問題,東查西找,找到一個好東東,在基礎上又修改了一下,問題終于被我解決了。

1。建立一個存儲過程

CREATE OR REPLACE PROCEDURE TIMER_AUTO_RECOMPILE_OBJS AS

CURSOR OBJECTS_LIST IS

SELECT OBJECT_NAME, OBJECT_TYPE

FROM USER_OBJECTS

WHERE STATUS = 'INVALID';

BEGIN

FOR V_OBJECT IN OBJECTS_LIST LOOP

IF V_OBJECT.OBJECT_TYPE = 'PROCEDURE' THEN

EXECUTE IMMEDIATE 'alter procedure ' || V_OBJECT.OBJECT_NAME ||

' compile';

ELSEIF V_OBJECT.OBJECT_TYPE = 'FUNCTION' THEN EXECUTE IMMEDIATE 'alter function ' || V_OBJECT.OBJECT_NAME || ' compile';

ELSIF V_OBJECT.OBJECT_TYPE = 'VIEW' THEN

EXECUTE IMMEDIATE 'alter view ' || V_OBJECT.OBJECT_NAME || ' compile';

ELSIF V_OBJECT.OBJECT_TYPE = 'MATERIALIZED VIEW' THEN

EXECUTE IMMEDIATE 'alter materialized view ' || V_OBJECT.OBJECT_NAME ||

' compile';

END IF;

END LOOP;

END;

2。在需要的時候執行,或者建立一個定時任務

exec dbms_job.submit(:job_id,'timer_auto_recompile_objs;',sysdate,'sysdate+1/24');

定時執行