144 lines
4.2 KiB
MySQL
144 lines
4.2 KiB
MySQL
|
|
----------------------------------------------------------------------------------------
|
||
|
|
--
|
||
|
|
-- File name: cs_sqlmon_binds.sql
|
||
|
|
--
|
||
|
|
-- Purpose: SQL Monitor Binds for given SQL_ID
|
||
|
|
--
|
||
|
|
-- Author: Carlos Sierra
|
||
|
|
--
|
||
|
|
-- Version: 2023/04/27
|
||
|
|
--
|
||
|
|
-- Usage: Execute connected to PDB.
|
||
|
|
--
|
||
|
|
-- Enter SQL_ID when requested.
|
||
|
|
--
|
||
|
|
-- Example: $ sqlplus / as sysdba
|
||
|
|
-- SQL> @cs_sqlmon_binds.sql
|
||
|
|
--
|
||
|
|
-- Notes: 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_sqlmon_binds';
|
||
|
|
DEF cs_hours_range_default = '168';
|
||
|
|
--
|
||
|
|
@@cs_internal/&&cs_set_container_to_cdb_root.
|
||
|
|
--
|
||
|
|
COL cs_hours_range_default NEW_V cs_hours_range_default NOPRI;
|
||
|
|
SELECT TRIM(TO_CHAR(LEAST(TRUNC((SYSDATE - MIN(snap_time)) * 24), TO_NUMBER('&&cs_hours_range_default.')))) AS cs_hours_range_default FROM &&cs_tools_schema..iod_sql_monitor
|
||
|
|
/
|
||
|
|
--
|
||
|
|
@@cs_internal/&&cs_set_container_to_curr_pdb.
|
||
|
|
--
|
||
|
|
@@cs_internal/cs_sample_time_from_and_to.sql
|
||
|
|
@@cs_internal/cs_snap_id_from_and_to.sql
|
||
|
|
--
|
||
|
|
PRO 3. SQL_ID:
|
||
|
|
DEF cs_sql_id = '&3.';
|
||
|
|
UNDEF 3;
|
||
|
|
--
|
||
|
|
SELECT '&&cs_file_prefix._&&cs_script_name._&&cs_sql_id.' cs_file_name FROM DUAL;
|
||
|
|
--
|
||
|
|
@@cs_internal/cs_signature.sql
|
||
|
|
@@cs_internal/cs_spool_head.sql
|
||
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sample_time_from." "&&cs_sample_time_to." "&&cs_sql_id."
|
||
|
|
@@cs_internal/cs_spool_id.sql
|
||
|
|
@@cs_internal/cs_spool_id_sample_time.sql
|
||
|
|
@@cs_internal/cs_spool_id_list_sql_id.sql
|
||
|
|
@@cs_internal/cs_print_sql_text.sql
|
||
|
|
@@cs_internal/&&cs_set_container_to_cdb_root.
|
||
|
|
--
|
||
|
|
COL key NOPRI;
|
||
|
|
COL sql_exec_start FOR A19;
|
||
|
|
COL last_refresh_time FOR A19;
|
||
|
|
COL seconds FOR 999,990;
|
||
|
|
COL status FOR A19;
|
||
|
|
COL sql_plan_hash_value FOR 9999999999 HEA 'PHV';
|
||
|
|
COL elapsed_secs FOR 999,990.000 HEA 'ELAP_SECS';
|
||
|
|
COL cpu_secs FOR 999,990.000 HEA 'CPU_SECS';
|
||
|
|
COL buffer_gets FOR 999,999,990;
|
||
|
|
COL disk_reads FOR 999,999,990;
|
||
|
|
COL pos FOR 999;
|
||
|
|
COL type FOR A20;
|
||
|
|
COL name_and_value FOR A200;
|
||
|
|
--
|
||
|
|
BREAK ON key SKIP PAGE ON sql_exec_start ON last_refresh_time ON seconds ON status ON sql_plan_hash_value ON elapsed_secs ON cpu_secs ON buffer_gets ON disk_reads;
|
||
|
|
--
|
||
|
|
PRO
|
||
|
|
PRO SQL MONITOR BINDS (&&cs_tools_schema..iod_sql_monitor)
|
||
|
|
PRO ~~~~~~~~~~~~~~~~~
|
||
|
|
--
|
||
|
|
WITH
|
||
|
|
mon AS (
|
||
|
|
SELECT s.key,
|
||
|
|
s.con_id,
|
||
|
|
s.sql_plan_hash_value,
|
||
|
|
s.sql_exec_id,
|
||
|
|
s.sql_exec_start,
|
||
|
|
s.last_refresh_time,
|
||
|
|
(s.last_refresh_time - s.sql_exec_start) * 24 * 3600 AS seconds,
|
||
|
|
s.status,
|
||
|
|
s.username,
|
||
|
|
s.sid,
|
||
|
|
s.session_serial# AS serial#,
|
||
|
|
s.elapsed_time,
|
||
|
|
s.cpu_time,
|
||
|
|
s.buffer_gets,
|
||
|
|
s.disk_reads,
|
||
|
|
s.module,
|
||
|
|
s.action,
|
||
|
|
s.program,
|
||
|
|
bv.pos,
|
||
|
|
bv.name,
|
||
|
|
bv.type,
|
||
|
|
bv.maxlen,
|
||
|
|
bv.len,
|
||
|
|
bv.value
|
||
|
|
FROM &&cs_tools_schema..iod_sql_monitor s,
|
||
|
|
xmltable( '/binds/bind'
|
||
|
|
passing xmltype(xmltype(REPLACE(REPLACE(ASCIISTR(s.binds_xml), '\FFFF'), CHR(0))))
|
||
|
|
COLUMNS name VARCHAR2( 30 ) path '@name' ,
|
||
|
|
pos NUMBER path '@pos',
|
||
|
|
type VARCHAR2( 15 ) path '@dtystr' ,
|
||
|
|
maxlen NUMBER path '@maxlen',
|
||
|
|
len NUMBER path '@len',
|
||
|
|
value VARCHAR2( 4000 ) path '.'
|
||
|
|
) bv
|
||
|
|
WHERE s.snap_time BETWEEN TO_DATE('&&cs_sample_time_from.', '&&cs_datetime_full_format.') AND TO_DATE('&&cs_sample_time_to.', '&&cs_datetime_full_format.')
|
||
|
|
AND s.sql_id = '&&cs_sql_id.'
|
||
|
|
AND s.binds_xml IS NOT NULL
|
||
|
|
)
|
||
|
|
SELECT key,
|
||
|
|
sql_exec_start,
|
||
|
|
last_refresh_time,
|
||
|
|
ROUND(elapsed_time / POWER(10, 6), 3) AS elapsed_secs,
|
||
|
|
ROUND(cpu_time / POWER(10, 6), 3) AS cpu_secs,
|
||
|
|
buffer_gets,
|
||
|
|
disk_reads,
|
||
|
|
sql_plan_hash_value,
|
||
|
|
status,
|
||
|
|
pos,
|
||
|
|
type,
|
||
|
|
name||' = '||value AS name_and_value
|
||
|
|
FROM mon
|
||
|
|
ORDER BY
|
||
|
|
key,
|
||
|
|
pos
|
||
|
|
/
|
||
|
|
--
|
||
|
|
PRO
|
||
|
|
PRO SQL> @&&cs_script_name..sql "&&cs_sample_time_from." "&&cs_sample_time_to." "&&cs_sql_id."
|
||
|
|
--
|
||
|
|
@@cs_internal/cs_spool_tail.sql
|
||
|
|
--
|
||
|
|
@@cs_internal/&&cs_set_container_to_curr_pdb.
|
||
|
|
--
|
||
|
|
@@cs_internal/cs_undef.sql
|
||
|
|
@@cs_internal/cs_reset.sql
|
||
|
|
--
|