云数据库OceanBase入门教程 OceanBase 分析分布式计划相关的查询问题

2024-02-26 开发教程 云数据库OceanBase入门教程 匿名 2

分布式计划根据以下步骤分析查询问题:

  1. 通过查看 (g)v$plan_cache_plan_stat视图、(g)v$sql_audit中对执行计划类型的记录,确定是否为分布式计划。

  2. 分析该执行计划是否正确。

  3. 通过 trace_id 关联查询 gv$sql_audit,查看所有执行的子计划耗时情况,每个子计划的 RPC 执行均对应一条 sql_audit 记录,分析该 sql_audit 记录来定位问题。

如下例所示,is_executor_rpc = 1表示子计划执行在 sql_audit 中记录,主要记录执行相关的信息。is_executor_rpc = 0表示接受 SQL 请求的线程在 sql_audit 中的记录。该记录含有 SQL 执行过程的信息,包括 SQL 信息、获取执行计划信息等。

obclient>SELECT/*+ PARALLEL(15)*/sql_id, is_executor_rpc, elapsed_time
FROM oceanbase.gv$sql_audit WHERE trace_id = 'YB420AB74FC6-00056349D323483A';
+----------------------------------+-----------------+--------------+
| sql_id | is_executor_rpc | elapsed_time |
+----------------------------------+-----------------+--------------+
| | 1 | 124 |
| | 1 | 191 |
| | 1 | 123447 |
| | 1 | 125 |
| 20172B18BC9EE3F806D4149895754CE0 | 0 | 125192 |
| | 1 | 148 |
| | 1 | 149 |
| | 1 | 140 |
+----------------------------------+-----------------+--------------+