---------------------------------------------------------------------------------------- -- -- File name: cs_spch_category.sql -- -- Purpose: Changes category for a SQL Patch 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_category.sql -- -- Notes: Accesses AWR data thus you must have an Oracle Diagnostics Pack License. -- -- Developed and tested on 12.1.0.2. -- --------------------------------------------------------------------------------------- -- @@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_category'; -- 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 (req): DEF cs_name = '&2.'; UNDEF 2; PRO -- PRO 3. Enter CATEGORY (opt) [{DEFAULT}|DISABLED|]: DEF category_passed = "&3."; UNDEF 3; -- COL cs_category NEW_V cs_category; SELECT CASE WHEN UPPER(NVL('&&category_passed.','DEFAULT')) IN ('DEF', 'DEFAULT') THEN 'DEFAULT' ELSE UPPER('&&category_passed.') END cs_category FROM DUAL; -- @@cs_internal/cs_spool_head.sql PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&cs_name." "&&cs_category." @@cs_internal/cs_spool_id.sql @@cs_internal/cs_spool_id_list_sql_id.sql -- PRO NAME : &&cs_name. PRO CATEGORY : &&cs_category. -- @@cs_internal/cs_print_sql_text.sql @@cs_internal/cs_plans_performance.sql @@cs_internal/cs_spch_internal_list.sql -- PRO PRO Changes category on "&&cs_name." to "&&cs_category." @@cs_internal/cs_spch_internal_category.sql -- @@cs_internal/cs_spch_internal_list.sql -- PRO PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&cs_name." "&&cs_category." -- @@cs_internal/cs_spool_tail.sql @@cs_internal/cs_undef.sql @@cs_internal/cs_reset.sql --