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

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
--