89 lines
2.2 KiB
SQL
89 lines
2.2 KiB
SQL
----------------------------------------------------------------------------------------
|
|
--
|
|
-- File name: cs_spch_disable.sql
|
|
--
|
|
-- Purpose: Disable one or all SQL Patches for given SQL_ID
|
|
--
|
|
-- Author: Carlos Sierra
|
|
--
|
|
-- Version: 2023/04/27
|
|
--
|
|
-- Usage: Connecting into PDB.
|
|
--
|
|
-- Enter SQL_ID and name when requested.
|
|
--
|
|
-- Example: $ sqlplus / as sysdba
|
|
-- SQL> @cs_spch_disable.sql
|
|
--
|
|
-- Notes: Accesses AWR data thus you must have an Oracle Diagnostics Pack License.
|
|
--
|
|
-- Developed and tested on 12.1.0.2 and 19c.
|
|
--
|
|
---------------------------------------------------------------------------------------
|
|
--
|
|
@@cs_internal/cs_primary.sql
|
|
@@cs_internal/cs_cdb_warn.sql
|
|
@@cs_internal/cs_set.sql
|
|
@@cs_internal/cs_def.sql
|
|
@@cs_internal/cs_file_prefix.sql
|
|
--
|
|
DEF cs_script_name = 'cs_spch_disable';
|
|
--
|
|
PRO 1. SQL_ID:
|
|
DEF cs_sql_id = '&1.';
|
|
UNDEF 1;
|
|
--
|
|
SELECT '&&cs_file_prefix._&&cs_script_name._&&cs_sql_id.' cs_file_name FROM DUAL;
|
|
--
|
|
@@cs_internal/cs_signature.sql
|
|
--
|
|
@@cs_internal/cs_plans_performance.sql
|
|
@@cs_internal/cs_spch_internal_list.sql
|
|
--
|
|
PRO
|
|
PRO 2. NAME (opt):
|
|
DEF cs_name = '&2.';
|
|
UNDEF 2;
|
|
PRO
|
|
--
|
|
@@cs_internal/cs_spool_head.sql
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&cs_name."
|
|
@@cs_internal/cs_spool_id.sql
|
|
@@cs_internal/cs_spool_id_list_sql_id.sql
|
|
--
|
|
PRO NAME : &&cs_name.
|
|
--
|
|
@@cs_internal/cs_print_sql_text.sql
|
|
@@cs_internal/cs_spch_internal_list.sql
|
|
@@cs_internal/cs_plans_performance.sql
|
|
--
|
|
PRO
|
|
PRO Disable name: "&&cs_name."
|
|
BEGIN
|
|
FOR i IN (SELECT name
|
|
FROM dba_sql_patches
|
|
WHERE signature = :cs_signature
|
|
AND status = 'ENABLED'
|
|
AND name = NVL('&&cs_name.', name)
|
|
ORDER BY name)
|
|
LOOP
|
|
$IF DBMS_DB_VERSION.ver_le_12_1
|
|
$THEN
|
|
DBMS_SQLDIAG.alter_sql_patch(name => i.name, attribute_name => 'STATUS', value => 'DISABLED'); -- 12c
|
|
$ELSE
|
|
DBMS_SQLDIAG.alter_sql_patch(name => i.name, attribute_name => 'STATUS', attribute_value => 'DISABLED'); -- 19c
|
|
$END
|
|
END LOOP;
|
|
END;
|
|
/
|
|
--
|
|
@@cs_internal/cs_spch_internal_list.sql
|
|
--
|
|
PRO
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&cs_name."
|
|
--
|
|
@@cs_internal/cs_spool_tail.sql
|
|
@@cs_internal/cs_undef.sql
|
|
@@cs_internal/cs_reset.sql
|
|
--
|