2026-03-12 20:23:15
This commit is contained in:
84
csierra/cs_sprf_unpack.sql
Normal file
84
csierra/cs_sprf_unpack.sql
Normal file
@@ -0,0 +1,84 @@
|
||||
----------------------------------------------------------------------------------------
|
||||
--
|
||||
-- File name: cs_sprf_unpack.sql
|
||||
--
|
||||
-- Purpose: Unpack from staging table one or all SQL Profiles for given SQL_ID
|
||||
--
|
||||
-- Author: Carlos Sierra
|
||||
--
|
||||
-- Version: 2023/02/28
|
||||
--
|
||||
-- Usage: Connecting into PDB.
|
||||
--
|
||||
-- Enter SQL_ID when requested.
|
||||
--
|
||||
-- Example: $ sqlplus / as sysdba
|
||||
-- SQL> @cs_sprf_unpack.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_sprf_unpack';
|
||||
--
|
||||
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_sprf_internal_list.sql
|
||||
--
|
||||
PRO
|
||||
PRO 2. Enter 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
|
||||
--
|
||||
PRO SQL_ID : &&cs_sql_id.
|
||||
PRO SIGNATURE : &&cs_signature.
|
||||
PRO SQL_HANDLE : &&cs_sql_handle.
|
||||
PRO NAME : &&cs_name.
|
||||
--
|
||||
@@cs_internal/cs_print_sql_text.sql
|
||||
@@cs_internal/cs_sprf_internal_list.sql
|
||||
@@cs_internal/cs_plans_performance.sql
|
||||
--
|
||||
PRO
|
||||
PRO Unpack name: "&&cs_name."
|
||||
BEGIN
|
||||
FOR i IN (SELECT obj_name name
|
||||
FROM &&cs_stgtab_owner..&&cs_stgtab_prefix._stgtab_sqlprof
|
||||
WHERE signature = :cs_signature
|
||||
AND obj_name = NVL('&&cs_name.', obj_name)
|
||||
ORDER BY obj_name)
|
||||
LOOP
|
||||
DBMS_SQLTUNE.unpack_stgtab_sqlprof(profile_name => i.name, replace => TRUE, staging_table_name => '&&cs_stgtab_prefix._stgtab_sqlprof', staging_schema_owner => '&&cs_stgtab_owner.');
|
||||
END LOOP;
|
||||
END;
|
||||
/
|
||||
--
|
||||
@@cs_internal/cs_sprf_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
|
||||
--
|
||||
Reference in New Issue
Block a user