FR [ 2783862 ] DBA_Recompile should recompile all materialized views
https://sourceforge.net/tracker/?func=detail&atid=879335&aid=2783862&group_id=176962 Implement Carlos' recommendations
This commit is contained in:
parent
7042986d00
commit
5241a5d6c9
|
@ -104,10 +104,6 @@ BEGIN
|
||||||
END LOOP; -- outer loop
|
END LOOP; -- outer loop
|
||||||
|
|
||||||
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
||||||
--
|
|
||||||
-- Refresh MVIEWS
|
|
||||||
dbms_mview.refresh_all_mviews(v_err, '?', null, true, false);
|
|
||||||
dbms_output.put_line('Refresh all mviews: '||v_err||' errors');
|
|
||||||
--
|
--
|
||||||
-- Print Message
|
-- Print Message
|
||||||
IF (LENGTH(v_Message) = 1) THEN
|
IF (LENGTH(v_Message) = 1) THEN
|
||||||
|
|
|
@ -1,157 +1 @@
|
||||||
CREATE OR REPLACE PROCEDURE DBA_Recompile
|
-- Reverted by script 460
|
||||||
(
|
|
||||||
p_PInstance_ID IN NUMBER -- DEFAULT NULL
|
|
||||||
)
|
|
||||||
/*************************************************************************
|
|
||||||
* The contents of this file are subject to the Adempiere License. You may
|
|
||||||
* obtain a copy of the License at http://www.adempiere.org/license.html
|
|
||||||
* Software is on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
|
|
||||||
* express or implied. See the License for details. Code: Adempiere ERP+CRM
|
|
||||||
* Copyright (C) 1999-2001 Jorg Janke, ComPiere, Inc. All Rights Reserved.
|
|
||||||
*************************************************************************
|
|
||||||
* $Id: DBA_Recompile.sql,v 1.1 2006/04/21 17:51:58 jjanke Exp $
|
|
||||||
***
|
|
||||||
* Title: Recompile all User_Objects
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Author: Teo Sarca, www.arhipac.ro
|
|
||||||
* * Recompile materialized views too
|
|
||||||
************************************************************************/
|
|
||||||
AS
|
|
||||||
-- Logistice
|
|
||||||
v_Message VARCHAR2(2000) := ' ';
|
|
||||||
v_Result NUMBER := 1; -- 0=failure
|
|
||||||
--
|
|
||||||
v_Buffer VARCHAR2(2000);
|
|
||||||
v_Line VARCHAR(100);
|
|
||||||
v_PrintInfo CHAR(1) := 'N'; -- Diagnostic
|
|
||||||
--
|
|
||||||
CURSOR Cur_Invalids IS
|
|
||||||
SELECT object_id, object_name, object_type
|
|
||||||
FROM user_objects
|
|
||||||
WHERE status <> 'VALID'
|
|
||||||
AND object_type IN ('VIEW', 'PACKAGE', 'PACKAGE BODY', 'FUNCTION',
|
|
||||||
'MATERIALIZED VIEW', -- arhipac: teo_sarca
|
|
||||||
'PROCEDURE', 'TRIGGER', 'JAVA CLASS')
|
|
||||||
ORDER BY object_type, object_name;
|
|
||||||
|
|
||||||
CURSOR Cur_Valids (p_id NUMBER) IS
|
|
||||||
SELECT 'FOUND'
|
|
||||||
FROM user_objects
|
|
||||||
WHERE status = 'VALID'
|
|
||||||
AND object_id = p_id;
|
|
||||||
|
|
||||||
-- failed compile
|
|
||||||
TYPE invalid_tab IS TABLE OF Cur_Invalids%ROWTYPE INDEX BY BINARY_INTEGER;
|
|
||||||
invalid_tab_rec invalid_tab;
|
|
||||||
|
|
||||||
count_compiled PLS_INTEGER;
|
|
||||||
valid_text VARCHAR2(5);
|
|
||||||
exec_cursor PLS_INTEGER := DBMS_SQL.OPEN_CURSOR;
|
|
||||||
sql_statement VARCHAR2(200);
|
|
||||||
count_object PLS_INTEGER := 0;
|
|
||||||
v_err BINARY_INTEGER;
|
|
||||||
|
|
||||||
BEGIN
|
|
||||||
LOOP
|
|
||||||
count_compiled := 0;
|
|
||||||
FOR ci IN Cur_Invalids LOOP
|
|
||||||
-- not unsuccessfuly compiled yet
|
|
||||||
IF NOT invalid_tab_rec.EXISTS(ci.object_id) THEN
|
|
||||||
IF (ci.object_type = 'JAVA CLASS') THEN
|
|
||||||
sql_statement := 'ALTER JAVA CLASS "' || ci.object_name || '" RESOLVE';
|
|
||||||
ELSIF (ci.object_type = 'PACKAGE BODY') THEN
|
|
||||||
sql_statement := 'ALTER PACKAGE ' || ci.object_name || ' COMPILE BODY';
|
|
||||||
ELSE
|
|
||||||
sql_statement := 'ALTER ' || ci.object_type || ' ' || ci.object_name || ' COMPILE';
|
|
||||||
END IF;
|
|
||||||
-- compile
|
|
||||||
BEGIN
|
|
||||||
count_object := count_object + 1;
|
|
||||||
DBMS_SQL.PARSE(exec_cursor, sql_statement, DBMS_SQL.NATIVE);
|
|
||||||
EXCEPTION
|
|
||||||
WHEN OTHERS THEN
|
|
||||||
NULL;
|
|
||||||
END;
|
|
||||||
--
|
|
||||||
OPEN Cur_Valids (ci.object_ID);
|
|
||||||
FETCH Cur_Valids INTO valid_text;
|
|
||||||
IF Cur_Valids%ROWCOUNT > 0 THEN
|
|
||||||
IF (v_PrintInfo = 'Y') THEN
|
|
||||||
DBMS_OUTPUT.PUT_LINE('OK: ' || ci.object_type || ' ' || ci.object_name);
|
|
||||||
END IF;
|
|
||||||
count_compiled := count_compiled + 1;
|
|
||||||
CLOSE Cur_Valids;
|
|
||||||
EXIT;
|
|
||||||
ELSE
|
|
||||||
IF (LENGTH(v_Message) < 1950) THEN
|
|
||||||
v_Message := v_Message || ci.object_name || ' ';
|
|
||||||
END IF;
|
|
||||||
IF (v_PrintInfo = 'Y') THEN
|
|
||||||
DBMS_OUTPUT.PUT_LINE('Error: ' || ci.object_type || ' ' || ci.object_name);
|
|
||||||
END IF;
|
|
||||||
--
|
|
||||||
invalid_tab_rec(ci.object_id).object_name := ci.object_name;
|
|
||||||
invalid_tab_rec(ci.object_id).object_type := ci.object_type;
|
|
||||||
CLOSE Cur_Valids;
|
|
||||||
END IF;
|
|
||||||
END IF; -- not unsuccessfuly compiled yet
|
|
||||||
END LOOP; -- Cur_Invalids
|
|
||||||
-- any other to be compiled
|
|
||||||
IF count_compiled = 0 THEN
|
|
||||||
EXIT;
|
|
||||||
END IF;
|
|
||||||
END LOOP; -- outer loop
|
|
||||||
|
|
||||||
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
|
||||||
--
|
|
||||||
-- Refresh MVIEWS
|
|
||||||
dbms_mview.refresh_all_mviews(v_err, '?', null, true, false);
|
|
||||||
dbms_output.put_line('Refresh all mviews: '||v_err||' errors');
|
|
||||||
--
|
|
||||||
-- Print Message
|
|
||||||
IF (LENGTH(v_Message) = 1) THEN
|
|
||||||
v_Message := 'All valid';
|
|
||||||
DBMS_OUTPUT.PUT_LINE(v_Message);
|
|
||||||
ELSIF (LENGTH(v_Message) > 80) THEN
|
|
||||||
v_Buffer := v_Message;
|
|
||||||
DBMS_OUTPUT.PUT_LINE('>');
|
|
||||||
WHILE (LENGTH(v_Buffer) > 0) LOOP
|
|
||||||
v_Line := SUBSTR(v_Buffer, 1, 80);
|
|
||||||
DBMS_OUTPUT.PUT_LINE(v_Line);
|
|
||||||
v_Buffer := SUBSTR(v_Buffer, 81);
|
|
||||||
END LOOP;
|
|
||||||
DBMS_OUTPUT.PUT_LINE('<');
|
|
||||||
v_Result := 0;
|
|
||||||
DBMS_OUTPUT.PUT_LINE('ERROR');
|
|
||||||
ELSE
|
|
||||||
DBMS_OUTPUT.PUT_LINE('>' || v_Message || '<');
|
|
||||||
v_Result := 0;
|
|
||||||
DBMS_OUTPUT.PUT_LINE('ERROR');
|
|
||||||
END IF;
|
|
||||||
|
|
||||||
<<FINISH_PROCESS>>
|
|
||||||
IF (p_PInstance_ID IS NOT NULL) THEN
|
|
||||||
-- Update AD_PInstance
|
|
||||||
UPDATE AD_PInstance
|
|
||||||
SET Updated = SysDate,
|
|
||||||
IsProcessing = 'N',
|
|
||||||
Result = v_Result, -- 1=success
|
|
||||||
ErrorMsg = v_Message
|
|
||||||
WHERE AD_PInstance_ID=p_PInstance_ID;
|
|
||||||
END IF;
|
|
||||||
COMMIT;
|
|
||||||
RETURN;
|
|
||||||
|
|
||||||
|
|
||||||
EXCEPTION
|
|
||||||
WHEN OTHERS THEN
|
|
||||||
DBMS_OUTPUT.PUT_LINE(SQLERRM);
|
|
||||||
IF DBMS_SQL.IS_OPEN(exec_cursor) THEN
|
|
||||||
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
|
||||||
END IF;
|
|
||||||
IF Cur_Valids%ISOPEN THEN
|
|
||||||
CLOSE Cur_Valids;
|
|
||||||
END IF;
|
|
||||||
END DBA_Recompile;
|
|
||||||
/
|
|
|
@ -0,0 +1,153 @@
|
||||||
|
CREATE OR REPLACE PROCEDURE DBA_Recompile
|
||||||
|
(
|
||||||
|
p_PInstance_ID IN NUMBER -- DEFAULT NULL
|
||||||
|
)
|
||||||
|
/*************************************************************************
|
||||||
|
* The contents of this file are subject to the Adempiere License. You may
|
||||||
|
* obtain a copy of the License at http://www.adempiere.org/license.html
|
||||||
|
* Software is on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either
|
||||||
|
* express or implied. See the License for details. Code: Adempiere ERP+CRM
|
||||||
|
* Copyright (C) 1999-2001 Jorg Janke, ComPiere, Inc. All Rights Reserved.
|
||||||
|
*************************************************************************
|
||||||
|
* $Id: DBA_Recompile.sql,v 1.1 2006/04/21 17:51:58 jjanke Exp $
|
||||||
|
***
|
||||||
|
* Title: Recompile all User_Objects
|
||||||
|
* Description:
|
||||||
|
*
|
||||||
|
* Author: Teo Sarca, www.arhipac.ro
|
||||||
|
* * Recompile materialized views too
|
||||||
|
************************************************************************/
|
||||||
|
AS
|
||||||
|
-- Logistice
|
||||||
|
v_Message VARCHAR2(2000) := ' ';
|
||||||
|
v_Result NUMBER := 1; -- 0=failure
|
||||||
|
--
|
||||||
|
v_Buffer VARCHAR2(2000);
|
||||||
|
v_Line VARCHAR(100);
|
||||||
|
v_PrintInfo CHAR(1) := 'N'; -- Diagnostic
|
||||||
|
--
|
||||||
|
CURSOR Cur_Invalids IS
|
||||||
|
SELECT object_id, object_name, object_type
|
||||||
|
FROM user_objects
|
||||||
|
WHERE status <> 'VALID'
|
||||||
|
AND object_type IN ('VIEW', 'PACKAGE', 'PACKAGE BODY', 'FUNCTION',
|
||||||
|
'MATERIALIZED VIEW', -- arhipac: teo_sarca
|
||||||
|
'PROCEDURE', 'TRIGGER', 'JAVA CLASS')
|
||||||
|
ORDER BY object_type, object_name;
|
||||||
|
|
||||||
|
CURSOR Cur_Valids (p_id NUMBER) IS
|
||||||
|
SELECT 'FOUND'
|
||||||
|
FROM user_objects
|
||||||
|
WHERE status = 'VALID'
|
||||||
|
AND object_id = p_id;
|
||||||
|
|
||||||
|
-- failed compile
|
||||||
|
TYPE invalid_tab IS TABLE OF Cur_Invalids%ROWTYPE INDEX BY BINARY_INTEGER;
|
||||||
|
invalid_tab_rec invalid_tab;
|
||||||
|
|
||||||
|
count_compiled PLS_INTEGER;
|
||||||
|
valid_text VARCHAR2(5);
|
||||||
|
exec_cursor PLS_INTEGER := DBMS_SQL.OPEN_CURSOR;
|
||||||
|
sql_statement VARCHAR2(200);
|
||||||
|
count_object PLS_INTEGER := 0;
|
||||||
|
v_err BINARY_INTEGER;
|
||||||
|
|
||||||
|
BEGIN
|
||||||
|
LOOP
|
||||||
|
count_compiled := 0;
|
||||||
|
FOR ci IN Cur_Invalids LOOP
|
||||||
|
-- not unsuccessfuly compiled yet
|
||||||
|
IF NOT invalid_tab_rec.EXISTS(ci.object_id) THEN
|
||||||
|
IF (ci.object_type = 'JAVA CLASS') THEN
|
||||||
|
sql_statement := 'ALTER JAVA CLASS "' || ci.object_name || '" RESOLVE';
|
||||||
|
ELSIF (ci.object_type = 'PACKAGE BODY') THEN
|
||||||
|
sql_statement := 'ALTER PACKAGE ' || ci.object_name || ' COMPILE BODY';
|
||||||
|
ELSE
|
||||||
|
sql_statement := 'ALTER ' || ci.object_type || ' ' || ci.object_name || ' COMPILE';
|
||||||
|
END IF;
|
||||||
|
-- compile
|
||||||
|
BEGIN
|
||||||
|
count_object := count_object + 1;
|
||||||
|
DBMS_SQL.PARSE(exec_cursor, sql_statement, DBMS_SQL.NATIVE);
|
||||||
|
EXCEPTION
|
||||||
|
WHEN OTHERS THEN
|
||||||
|
NULL;
|
||||||
|
END;
|
||||||
|
--
|
||||||
|
OPEN Cur_Valids (ci.object_ID);
|
||||||
|
FETCH Cur_Valids INTO valid_text;
|
||||||
|
IF Cur_Valids%ROWCOUNT > 0 THEN
|
||||||
|
IF (v_PrintInfo = 'Y') THEN
|
||||||
|
DBMS_OUTPUT.PUT_LINE('OK: ' || ci.object_type || ' ' || ci.object_name);
|
||||||
|
END IF;
|
||||||
|
count_compiled := count_compiled + 1;
|
||||||
|
CLOSE Cur_Valids;
|
||||||
|
EXIT;
|
||||||
|
ELSE
|
||||||
|
IF (LENGTH(v_Message) < 1950) THEN
|
||||||
|
v_Message := v_Message || ci.object_name || ' ';
|
||||||
|
END IF;
|
||||||
|
IF (v_PrintInfo = 'Y') THEN
|
||||||
|
DBMS_OUTPUT.PUT_LINE('Error: ' || ci.object_type || ' ' || ci.object_name);
|
||||||
|
END IF;
|
||||||
|
--
|
||||||
|
invalid_tab_rec(ci.object_id).object_name := ci.object_name;
|
||||||
|
invalid_tab_rec(ci.object_id).object_type := ci.object_type;
|
||||||
|
CLOSE Cur_Valids;
|
||||||
|
END IF;
|
||||||
|
END IF; -- not unsuccessfuly compiled yet
|
||||||
|
END LOOP; -- Cur_Invalids
|
||||||
|
-- any other to be compiled
|
||||||
|
IF count_compiled = 0 THEN
|
||||||
|
EXIT;
|
||||||
|
END IF;
|
||||||
|
END LOOP; -- outer loop
|
||||||
|
|
||||||
|
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
||||||
|
--
|
||||||
|
-- Print Message
|
||||||
|
IF (LENGTH(v_Message) = 1) THEN
|
||||||
|
v_Message := 'All valid';
|
||||||
|
DBMS_OUTPUT.PUT_LINE(v_Message);
|
||||||
|
ELSIF (LENGTH(v_Message) > 80) THEN
|
||||||
|
v_Buffer := v_Message;
|
||||||
|
DBMS_OUTPUT.PUT_LINE('>');
|
||||||
|
WHILE (LENGTH(v_Buffer) > 0) LOOP
|
||||||
|
v_Line := SUBSTR(v_Buffer, 1, 80);
|
||||||
|
DBMS_OUTPUT.PUT_LINE(v_Line);
|
||||||
|
v_Buffer := SUBSTR(v_Buffer, 81);
|
||||||
|
END LOOP;
|
||||||
|
DBMS_OUTPUT.PUT_LINE('<');
|
||||||
|
v_Result := 0;
|
||||||
|
DBMS_OUTPUT.PUT_LINE('ERROR');
|
||||||
|
ELSE
|
||||||
|
DBMS_OUTPUT.PUT_LINE('>' || v_Message || '<');
|
||||||
|
v_Result := 0;
|
||||||
|
DBMS_OUTPUT.PUT_LINE('ERROR');
|
||||||
|
END IF;
|
||||||
|
|
||||||
|
<<FINISH_PROCESS>>
|
||||||
|
IF (p_PInstance_ID IS NOT NULL) THEN
|
||||||
|
-- Update AD_PInstance
|
||||||
|
UPDATE AD_PInstance
|
||||||
|
SET Updated = SysDate,
|
||||||
|
IsProcessing = 'N',
|
||||||
|
Result = v_Result, -- 1=success
|
||||||
|
ErrorMsg = v_Message
|
||||||
|
WHERE AD_PInstance_ID=p_PInstance_ID;
|
||||||
|
END IF;
|
||||||
|
COMMIT;
|
||||||
|
RETURN;
|
||||||
|
|
||||||
|
|
||||||
|
EXCEPTION
|
||||||
|
WHEN OTHERS THEN
|
||||||
|
DBMS_OUTPUT.PUT_LINE(SQLERRM);
|
||||||
|
IF DBMS_SQL.IS_OPEN(exec_cursor) THEN
|
||||||
|
DBMS_SQL.CLOSE_CURSOR(exec_cursor);
|
||||||
|
END IF;
|
||||||
|
IF Cur_Valids%ISOPEN THEN
|
||||||
|
CLOSE Cur_Valids;
|
||||||
|
END IF;
|
||||||
|
END DBA_Recompile;
|
||||||
|
/
|
|
@ -0,0 +1 @@
|
||||||
|
-- oracle specific
|
Loading…
Reference in New Issue