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