91 lines
2.8 KiB
SQL
91 lines
2.8 KiB
SQL
----------------------------------------------------------------------------------------
|
|
--
|
|
-- File name: cs_spbl_expdp.sql
|
|
--
|
|
-- Purpose: Packs into staging table one or all SQL Plan Baselines for given SQL_ID
|
|
-- and Exports such Baselines using Datapump
|
|
--
|
|
-- Author: Carlos Sierra
|
|
--
|
|
-- Version: 2023/04/27
|
|
--
|
|
-- Usage: Connecting into PDB.
|
|
--
|
|
-- Enter SQL_ID when requested.
|
|
--
|
|
-- Example: $ sqlplus / as sysdba
|
|
-- SQL> @cs_spbl_expdp.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_spbl_expdp';
|
|
--
|
|
PRO 1. SQL_ID:
|
|
DEF cs_sql_id = '&1.';
|
|
UNDEF 1;
|
|
--
|
|
SELECT '&&cs_file_prefix._&&cs_script_name._&&cs_sql_id._SPM_EXPDP' cs_file_name FROM DUAL;
|
|
DEF cs_dp_file_name = '';
|
|
COL cs_dp_file_name NEW_V cs_dp_file_name NOPRI;
|
|
SELECT REPLACE('&&cs_file_name.', '&&cs_file_dir.') AS cs_dp_file_name FROM DUAL;
|
|
--
|
|
@@cs_internal/cs_signature.sql
|
|
--
|
|
PRO
|
|
ACCEPT sys_password CHAR PROMPT 'Enter SYS Password (hidden): ' HIDE
|
|
--
|
|
@@cs_internal/cs_spool_head.sql
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id."
|
|
@@cs_internal/cs_spool_id.sql
|
|
@@cs_internal/cs_spool_id_list_sql_id.sql
|
|
--
|
|
PRO TEMP_DIR : "&&cs_temp_dir."
|
|
--
|
|
@@cs_internal/cs_print_sql_text.sql
|
|
--
|
|
DEF cs_plan_name = '';
|
|
@@cs_internal/cs_spbl_internal_stgtab.sql
|
|
@@cs_internal/cs_spbl_internal_stgtab_delete.sql
|
|
@@cs_internal/cs_spbl_internal_pack.sql
|
|
--
|
|
@@cs_internal/cs_temp_dir_create.sql
|
|
--
|
|
HOS expdp \"sys/&&sys_password.@&&cs_easy_connect_string. AS SYSDBA\" DIRECTORY=CS_TEMP_DIR DUMPFILE=&&cs_dp_file_name..dmp LOGFILE=&&cs_dp_file_name..expdb.log TABLES=&&cs_stgtab_owner..&&cs_stgtab_prefix._stgtab_baseline QUERY=\"WHERE signature = &&cs_signature. AND BITAND\(status\, 1\) \<\> 0 AND BITAND\(status\, 2\) \<\> 0\" EXCLUDE=STATISTICS
|
|
UNDEF sys_password
|
|
--
|
|
HOS cp &&cs_temp_dir./&&cs_dp_file_name..* /tmp/
|
|
HOS chmod 644 /tmp/&&cs_dp_file_name..*
|
|
--
|
|
@@cs_internal/cs_temp_dir_drop.sql
|
|
--
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sql_id."
|
|
--
|
|
@@cs_internal/cs_spool_tail.sql
|
|
@@cs_internal/cs_undef.sql
|
|
@@cs_internal/cs_reset.sql
|
|
--
|
|
PRO
|
|
PRO Exported DataPump Files
|
|
PRO ~~~~~~~~~~~~~~~~~~~~~~~
|
|
HOS ls -lt /tmp/&&cs_dp_file_name..*
|
|
PRO
|
|
PRO On target Host:
|
|
PRO ~~~~~~~~~~~~~~~
|
|
PRO 1. $ scp &&cs_host_name.:/tmp/&&cs_dp_file_name..dmp /tmp/
|
|
PRO Note: command above works if target and source and on same Region, else scp into your pc/mac then into target
|
|
PRO
|
|
PRO 2. SQL> @cs_spbl_impdp.sql "&&cs_dp_file_name..dmp" "&&cs_sql_id." "&&cs_plan_name."
|
|
PRO Note: execute command above connected into PDB (i.e. &&cs_con_name.)
|
|
PRO
|
|
--
|