GaussDB-EXPLAIN PLAN

75 阅读2分钟

GaussDB-EXPLAIN PLAN

功能描述

通过EXPLAIN PLAN命令可以将查询执行的计划信息存储于PLAN_TABLE表中。与EXPLAIN命令不同的是,EXPLAIN PLAN仅将计划信息进行存储,而不会打印到屏幕。

注意事项
  • EXPLAIN PLAN不支持在DN上执行。
  • 对于执行错误的SQL语句无法进行计划信息的收集。
  • PLAN_TABLE中的数据是session级生命周期并且session隔离和用户隔离,用户只能看到当前session、当前用户的数据。
  • PLAN_TABLE无法与GDS外表进行关联查询。
  • 对于不能下推的查询,执行EXPLAIN PLAN后PLAN_TABLE中的object仅收集到REMOTE_QUERY或CTE等信息。详见示例 2
  • EXPLAIN中的PLAN选项表示需要将计划信息存储于PLAN_TABLE中,存储成功将返回“EXPLAIN SUCCESS”。
  • 用户可通过STATEMENT_ID对查询设置标签,输入的标签信息也将存储于PLAN_TABLE中。
  • 执行EXPLAIN PLAN 后会将计划信息自动存储于PLAN_TABLE中,不支持对PLAN_TABLE进行INSERT、UPDATE、ANALYZE等操作。PLAN_TABLE详细介绍见PLAN_TABLE
语法格式

| ``` EXPLAIN PLAN [ SET STATEMENT_ID = name ] FOR statement ;

| ----------------------------------------------------------------- |

#### 参数说明

-   **name**

    查询标签。

    取值范围:字符串

    ![](https://p3-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/3c597c6cd83f4b1f8bff1286f853c244~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAgamVycnl3YW5nMTk4Mw==:q75.awebp?rk3s=f64ab15b&x-expires=1770970902&x-signature=HNlSjetOwrFwvJJDgfhHcoCZD4w%3D)

    用户在执行EXPLAIN PLAN时,如果没有设置STATEMENT_ID,则默认为空值。同时,用户可输入的STATEMENT_ID最大长度为30个字节,超过长度将会报错。

<!---->

-   **statement**

    指定要分析的SQL语句。

#### 示例 1

| ```
--创建表foo1,foo2。 gaussdb=# CREATE TABLE foo1(f1 int, f2 text, f3 text[]); gaussdb=# CREATE TABLE foo2(f1 int, f2 text, f3 text[]);  --执行EXPLAIN PLAN。 gaussdb=# EXPLAIN PLAN SET STATEMENT_ID = 'TPCH-Q4' FOR SELECT f1, count(*) FROM foo1 WHERE f1 > 1 AND f1 < 3 AND EXISTS (SELECT * FROM foo2) GROUP BY f1;  --查询PLAN_TABLE。 gaussdb=# SELECT * FROM plan_table;  --清理PLAN_TABLE表中的数据,删除表foo1,foo2。 gaussdb=# DELETE FROM plan_table WHERE STATEMENT_ID = 'TPCH-Q4'; gaussdb=# DROP TABLE foo1; gaussdb=# DROP TABLE foo2; 
``` |
| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

[]()[]()

#### 示例 2

| ```
--关闭enable_stream_recursive,使得with recursive关联查询不能下推。 gaussdb=# SET enable_stream_recursive = off;  --创建表chinamap。 gaussdb=# CREATE TABLE chinamap (   id integer,   pid integer,   name text ) DISTRIBUTE BY hash(id);  --plan_table收集的计划。 gaussdb=# EXPLAIN PLAN SET statement_id = 'cte can not be push down' FOR WITH RECURSIVE rq AS (   SELECT id, name FROM chinamap WHERE id = 11   UNION ALL   SELECT origin.id, rq.name || ' > ' || origin.name   FROM rq JOIN chinamap origin ON origin.pid = rq.id ) SELECT id, name FROM rq ORDER BY 1;  --查询PLAN_TABLE。 gaussdb=# SELECT * FROM plan_table;  --删除表chinamap。 gaussdb=# DROP TABLE chinamap; 
``` |
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |

更多详情请参考GaussDB 文档中心:<https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/productdesc/qlh_03_0001.html>