2026-03-12 20:23:15
This commit is contained in:
90
csierra/cs_spbl_expdp.sql
Normal file
90
csierra/cs_spbl_expdp.sql
Normal file
@@ -0,0 +1,90 @@
|
||||
----------------------------------------------------------------------------------------
|
||||
--
|
||||
-- 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
|
||||
--
|
||||
Reference in New Issue
Block a user