[20221208]完善bind_cap_awr.sql指令碼.txt
[20221208]完善bind_cap_awr.sql指令碼.txt
--//以前寫的抓取繫結變數的指令碼,如果繫結變數型別是timestamp型別是儲存在v$sql_bind_capture.value_anydata中.
--//我以前的寫法如下,不合理多建立一個欄位:
$ cat bind_cap_awr.sql
set verify off
prompt
prompt @bind_cap_awr sql_id [column]
prompt
column value_string format a50
column datatype_string format a15
break on snap_id on sql_id on was_captured on last_captured skip 1
select replace(sql_fulltext,chr(13),'') c200 from v$sql where sql_id='&1' and rownum<=1;
--select replace(sql_text,chr(13),'') c200 from DBA_HIST_SQLTEXT where sql_id='&1' and rownum<=1;
SELECT snap_id,
INSTANCE_NUMBER,
sql_id,
was_captured,
last_captured,
name,
position,
max_length,
datatype_string,
DECODE (
datatype_string,
'DATE', TO_CHAR (TO_DATE (value_string, 'mm/dd/yy hh24:mi:ss'),
'yyyy/mm/dd hh24:mi:ss'),
value_string)
value_string,
decode(datatype_string,'TIMESTAMP',ANYDATA.accesstimestamp (value_anydata)) c30
FROM DBA_HIST_SQLBIND
WHERE sql_id = '&1' AND was_captured = 'YES' and dup_position is null and lower(name) like lower('%'||nvl('&&2',name)||'%')
ORDER BY snap_id ,last_captured, was_captured, position;
clear break
--//改寫後程式碼如下:
$ cat bind_cap_awr.sql
set verify off
prompt
prompt @bind_cap_awr sql_id [column]
prompt
column value_string format a50
column datatype_string format a15
break on snap_id on sql_id on was_captured on last_captured skip 1
select replace(sql_fulltext,chr(13),'') c200 from v$sql where sql_id='&1' and rownum<=1;
--select replace(sql_text,chr(13),'') c200 from DBA_HIST_SQLTEXT where sql_id='&1' and rownum<=1;
SELECT snap_id
,INSTANCE_NUMBER
,sql_id
,was_captured
,last_captured
,name
,position
,max_length
,datatype_string
,DECODE
(
datatype_string
,'DATE', TO_CHAR ( TO_DATE (value_string, 'mm/dd/yy hh24:mi:ss') ,'yyyy/mm/dd hh24:mi:ss')
,'TIMESTAMP', TO_CHAR ( ANYDATA.accesstimestamp (value_anydata) ,'yyyy/mm/dd hh24:mi:ss.ff9')
,value_string
)
value_string
-- decode(datatype_string,'TIMESTAMP',ANYDATA.accesstimestamp (value_anydata)) c30
FROM DBA_HIST_SQLBIND
WHERE sql_id = '&1'
AND was_captured = 'YES'
AND dup_position IS NULL
AND LOWER (name) LIKE LOWER ('%' || NVL ('&&2', name) || '%')
ORDER BY snap_id
,last_captured
,was_captured
,position;
clear break
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-2927700/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 群暉DS218+部署mysql
- 眼見為實,看看MySQL中的隱藏列!
- MySQL空間暴漲150G導致鎖定,發生了什麼
- 用友降運維成本實踐:OceanBase替換MySQL,實現高可用
- MySQL最典型和實用的熱備指令碼實戰
- 【資料庫資料恢復】MS SQL資料庫附加資料庫出錯怎麼恢復資料?
- 資料庫日常實操優質文章分享(含Oracle、MySQL等) | 11月刊
- MySQL並行複製延時時間不準確
- 快速學會慢查詢SQL排查
- 秒級查詢之開源分散式SQL查詢引擎Presto實操-上
- 一步步帶你設計MySQL索引資料結構
- [20221208]完善bind_cap.sql指令碼.txt
- PostgreSQL/MogDB/openGauss怎樣獲取表上依賴於該表的檢視
- 如何實現工具無關化?關於自動化測試指令碼的設計
- 簡單介紹PostgreSQL解析URL的方法
- MySQL常用效能指標
- PostgreSQL的wal_buffers
- benchmarksql 5.0壓測MySQL