Files
oracle/csierra/cs_spch_create.sql
2026-03-12 21:23:47 +01:00

103 lines
4.6 KiB
SQL

----------------------------------------------------------------------------------------
--
-- File name: cs_spch_create.sql
--
-- Purpose: Create a SQL Patch for given SQL_ID
--
-- Author: Carlos Sierra
--
-- Version: 2023/04/27
--
-- Usage: Connecting into PDB.
--
-- Enter SQL_ID and PLAN_HASH_VALUE when requested.
--
-- Example: $ sqlplus / as sysdba
-- SQL> @cs_spch_create.sql
--
-- Notes: Accesses AWR data thus you must have an Oracle Diagnostics Pack License.
--
-- Developed and tested on 12.1.0.2.
--
-- Other less common CBO Hints:
-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~
-- OPT_PARAM('_b_tree_bitmap_plans' 'FALSE') OPT_PARAM('_no_or_expansion' 'TRUE')
-- CARDINALITY(T 1)
-- OPT_ESTIMATE(TABLE T ROWS=1) e.g.: OPT_ESTIMATE(@SEL$1 TABLE REPLICATION_LOG_V2 ROWS=1000000)
-- BIND_AWARE
-- PUSH_PRED(@SEL$XXXXXXXX)
-- NO_EXPAND
--
-- OPT_PARAM('_optimizer_unnest_all_subqueries' 'FALSE') -- DBPERF-6362 DNSVCNAPI cqhcc9c504qk5 getValues(INTERNAL_ZONES,ZoneIdIndex) after removing redundant predicate
-- OPT_PARAM('_unnest_subquery' 'FALSE') -- DBPERF-6362 DNSVCNAPI cqhcc9c504qk5 getValues(INTERNAL_ZONES,ZoneIdIndex) after removing redundant predicate
-- OPT_PARAM('_first_k_rows_dynamic_proration' 'FALSE') -- DBPERF-6362 DNSVCNAPI cqhcc9c504qk5 getValues(INTERNAL_ZONES,ZoneIdIndex) after removing redundant predicate
-- OPT_PARAM('_optim_peek_user_binds' 'FALSE') -- DBPERF-8653 Suboptimal performance on a query with range predicate on column where all rows have same prefix on leading 56 characters 9sjq5yhu22678 performScanQuery(instanceConfigEvents,HashRangeIndex)
--
-- Fix Control CBO Hints:
-- ~~~~~~~~~~~~~~~~~~~~~
-- OPT_PARAM('_fix_control' '9550277:ON') -- DBPERF-8595 9550277 Use Column Groups Selectivity and do not load Column Histogram Statistics
-- OPT_PARAM('_fix_control' '5922070:OFF') -- DBPERF-5188 DBPERF-5443 DBPERF-5475 DBPERF-5513 DBPERF-5839 DBPERF-5881 DBPERF-6264 DBPERF-6302 DBPERF-6337 DBPERF-84 DBPERF-262 DBPERFOCI-54 IOD-31530 IOD-34530 WFAAS-5928 ... 5922070: NO COLUMN EQUIVALENCE BASED ON EQUIJOIN IS DONE IN STMT WITH GROUP BY
-- OPT_PARAM('_fix_control' '21971099:OFF') -- DBPERF-5204 NAT_GATEWAY 9tbzxxg29px0p performScanQuery(RETRY_TOKENS,HashRangeIndex) 21971099: WRONG CARDINALITY FROM SQL ANALYTIC WINDOWS FUNCTIONS
-- OPT_PARAM('_fix_control' '13321547:OFF') -- 13321547: ANALYTICAL QUERY WINDOW SORT
-- OPT_PARAM('_fix_control' '6674254:OFF') -- DBPERF-6362 DNSVCNAPI cqhcc9c504qk5 getValues(INTERNAL_ZONES,ZoneIdIndex) after removing redundant predicate 6674254: FIRST_ROWS(X) HINT CAUSING BAD PLAN
---------------------------------------------------------------------------------------
--
@@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_create';
--
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_zapper_managed.
--
@@cs_internal/cs_plans_performance.sql
@@cs_internal/cs_spch_internal_list.sql
--
COL default_hints_text NEW_V default_hints_text NOPRI;
SELECT q'[&&hints_text.]'||CASE WHEN '&&cs_kiev_table_name.' IS NOT NULL THEN ' LEADING(@SEL$1 &&cs_kiev_table_name.)' END||q'[ OPT_PARAM('_b_tree_bitmap_plans' 'FALSE') OPT_PARAM('_no_or_expansion' 'TRUE')]' AS default_hints_text FROM DUAL;
PRO
PRO To enhance diagnostics: MONITOR GATHER_PLAN_STATISTICS
PRO
PRO For most KIEV scans use default: &&default_hints_text.
PRO
PRO 2. CBO_HINT(S):
DEF hints_text = "&2.";
UNDEF 2;
COL hints_text NEW_V hints_text NOPRI;
SELECT NVL(q'[&&hints_text.]', q'[&&default_hints_text.]') AS hints_text FROM DUAL;
--
@@cs_internal/cs_spool_head.sql
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&hints_text."
@@cs_internal/cs_spool_id.sql
@@cs_internal/cs_spool_id_list_sql_id.sql
--
PRO CBO HINTS : "&&hints_text."
--
@@cs_internal/cs_print_sql_text.sql
-- drop existing patch if any
@@cs_internal/cs_spch_internal_drop.sql
--
PRO
PRO Create name: "spch_&&cs_sql_id."
@@cs_internal/cs_spch_internal_create.sql
--
@@cs_internal/cs_spch_internal_list.sql
PRO
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id." "&&hints_text."
--
@@cs_internal/cs_spool_tail.sql
@@cs_internal/cs_undef.sql
@@cs_internal/cs_reset.sql
--