W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
SQL Trace 能夠交互式的提供上一次執(zhí)行的 SQL 請(qǐng)求執(zhí)行過程信息及各階段的耗時(shí)。
SQL Trace 功能默認(rèn)是關(guān)閉的,可通過 session 變量來控制其打開和關(guān)閉。
obclient>SET ob_enable_trace_log = 1;
obclient>SET ob_enable_trace_log = 0;
當(dāng) SQL Trace 功能打開后,執(zhí)行需要診斷的 SQL,然后通過 ?SHOW TRACE
? 能夠查看該 SQL 執(zhí)行的信息。這些執(zhí)行信息以表格方式輸出,每列說明如下:
列名 |
說明 |
---|---|
Title |
記錄執(zhí)行過程某一個(gè)階段點(diǎn) |
KeyValue |
記錄某一個(gè)階段點(diǎn)產(chǎn)生的一些執(zhí)行信息 |
Time |
記錄上一個(gè)階段點(diǎn)到這次階段點(diǎn)執(zhí)行耗時(shí)(us) |
obclient> SET ob_enable_trace_log = 1;
obclient> CREATE TABLE t1(c1 INT,c2 INT,c3 INT);
Query OK, 0 rows affected (0.02 sec)
obclient> INSERT INTO t1 VALUES(1,1,1);
Query OK, 1 rows affected (0.02 sec)
obclient> INSERT INTO t1 VALUES(2,2,2);
Query OK, 1 rows affected (0.02 sec)
obclient>SELECT * FROM t1 WHERE c1 = 1;
+----+------+------+
| c1 | c2 | c3 |
+----+------+------+
| 1 | 1 | 1 |
+----+------+------+
obclient> SHOW TRACE;
+------------------------------+---------------------------------------------------------------------------------------------------+
| TITLE | KEYVALUE | TIME |
+------------------------------+----------------------------------------------------------------------------+------+
| process begin | in_queue_time:17, receive_ts:1612420489580707, enqueue_ts:1612420489580709 | 0 |
| query begin | trace_id:YB42AC1E87E6-0005B8AB2D57844F | 1 |
| parse begin | stmt:"set ob_enable_trace_log = 1", stmt_len:27 | 62 |
| pc get plan begin | NULL | 9 |
| pc get plan end | NULL | 19 |
| transform_with_outline begin | NULL | 1 |
| transform_with_outline end | NULL | 31 |
| resolve begin | NULL | 21 |
| resolve end | NULL | 33 |
| execution begin | arg1:false, end_trans_cb:false | 14 |
| start_auto_end_plan begin | NULL | 39 |
| start_auto_end_plan end | NULL | 1 |
| execution end | NULL | 11 |
| query end | NULL | 39 |
+------------------------------+---------------------------------------------------------------------------------------------+------+
SHOW TRACE
? 結(jié)果說明如下:
trace_id
? 可以作為 sql_audit 中的過濾條件,快速找到該 SQL 執(zhí)行信息,同時(shí)也可以通過該 ?trace_id
? 快速查找相關(guān)的 observer 日志。plan_id
? 可以用于在 ?v$plan_cache_plan_explain
? 中查看 plan cache 中緩存的具體執(zhí)行計(jì)劃。phy_plan_type
? 指出該次執(zhí)行計(jì)劃的類型(1 表示本地計(jì)劃/2 表示遠(yuǎn)程計(jì)劃/3 表示分布式計(jì)劃),可以輔助 SQL 診斷。Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: