PostgreSQL查看sql的执行计划

PostgreSQL查看sql的执行计划

基础信息
OS版本:Red Hat Enterprise Linux Server release 7.9 (Maipo)
DB版本:16.2
pg软件目录:/home/pg16/soft
pg数据目录:/home/pg16/data
端口:5777

在PostgreSQL中,查看SQL查询的执行计划是性能调优和问题诊断的重要步骤。PostgreSQL提供了一个叫做EXPLAIN的命令,可以让你查看查询的执行计划。通过EXPLAIN命令,你可以看到查询将如何执行,包括访问表的方法和使用的索引,预计的执行成本等。

使用EXPLAIN命令

EXPLAIN命令有几种变体,你可以根据需要选择使用。

  1. 基本形式

    这会展示查询的执行计划,但不会执行查询:

    EXPLAIN SELECT * FROM your_table WHERE condition;
    
  2. 带有分析

    这会展示执行计划并实际执行查询,提供实际执行时间等详细信息:

    EXPLAIN ANALYZE SELECT * FROM your_table WHERE condition;
    
  3. 可视化格式

    这个选项将结果格式化为更易读的文本树状结构(在PostgreSQL 13及以上版本中可用):

    EXPLAIN (FORMAT JSON) SELECT * FROM your_table WHERE condition;
    

    或者:

    EXPLAIN (FORMAT YAML) SELECT * FROM your_table WHERE condition;
    
  4. 其他有用参数

    • BUFFERS: 显示缓冲区使用情况。
    • VERBOSE: 提供更详细的信息。
    • COSTS: 显示执行成本(默认启用)。
    • TIMING: 显示每个操作消耗的时间(EXPLAIN ANALYZE中默认启用)。

    示例:

    EXPLAIN (ANALYZE, BUFFERS) SELECT * FROM your_table WHERE condition;
    

输出解释

EXPLAINEXPLAIN ANALYZE 的输出通常包含以下信息:

  • Node Type: 表示执行计划的每个节点的类型,如Seq Scan(顺序扫描)、Index Scan(索引扫描)等。
  • Cost: 预估的开始和结束成本,单位是cost,主要用来比较不同的查询计划。
  • Rows: 预估返回的行数。
  • Width: 每行的预估字节宽度。
  • Actual Time: 实际执行的时间(仅在EXPLAIN ANALYZE中出现)。
  • Loops: 循环次数(仅在EXPLAIN ANALYZE中出现)。

使用注意事项

  • 测试环境: EXPLAIN ANALYZE会实际执行查询,因此应在测试环境或在不影响生产的情况下使用。
  • 缓存影响: 多次执行同一查询可能会因为数据缓存导致不准确的分析结果。在分析前重启数据库或清除缓存可能会有所帮助。
  • 复合查询: 对复杂查询或涉及多个表的查询,通常需要更详细的执行计划分析,查看各个步骤的执行成本和时间。
示例 1:基本形式

查询:

postgres=# SELECT * FROM t2 WHERE id = '99';
 id |  name   
----+---------
 99 | haha_99
(1 row)

执行计划:

postgres=# EXPLAIN SELECT * FROM t2 WHERE id = '99';
                            QUERY PLAN                            
------------------------------------------------------------------
 Index Scan using idx_t2 on t2  (cost=0.28..8.29 rows=1 width=12)
   Index Cond: (id = 99)
(2 rows)

经过格式化的执行计划

postgres=# EXPLAIN (FORMAT YAML) SELECT * FROM t2 WHERE id = '99';
          QUERY PLAN           
-------------------------------
 - Plan:                      +
     Node Type: "Index Scan"  +
     Parallel Aware: false    +
     Async Capable: false     +
     Scan Direction: "Forward"+
     Index Name: "idx_t2"     +
     Relation Name: "t2"      +
     Alias: "t2"              +
     Startup Cost: 0.28       +
     Total Cost: 8.29         +
     Plan Rows: 1             +
     Plan Width: 12           +
     Index Cond: "(id = 99)"
(1 row)

postgres=# 
示例 2:带有分析信息

查询:

postgres=# EXPLAIN ANALYZE SELECT * FROM t2 WHERE id = '99';
                                                 QUERY PLAN                                                 
------------------------------------------------------------------------------------------------------------
 Index Scan using idx_t2 on t2  (cost=0.28..8.29 rows=1 width=12) (actual time=0.014..0.015 rows=1 loops=1)
   Index Cond: (id = 99)
 Planning Time: 0.063 ms
 Execution Time: 0.029 ms
(4 rows)

通过分析这些信息,你可以更加了解查询的性能瓶颈,并做出相应的优化建议,例如添加索引、更改查询结构等。

谨记:心存敬畏,行有所止。

  • 15
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当分析 PostgreSQL SQL 语句的执行计划时,可以使用 EXPLAIN 关键字来获取查询计划的详细信息。EXPLAIN 关键字可以与 SELECT、INSERT、UPDATE 或 DELETE 语句一起使用。 执行 EXPLAIN 查询时,PostgreSQL 会返回一个描述查询计划的结果集。这个结果集包含了查询计划中每个步骤的详细信息,包括使用的索引、连接类型、排序方式等等。 以下是分析 PostgreSQL SQL 语句执行计划的步骤: 1. 在 SQL 语句前加上 EXPLAIN 关键字,例如:EXPLAIN SELECT * FROM table_name; 2. 执行该 SQL 语句,获取查询计划的结果集; 3. 分析结果集中的每一行,了解查询计划中每个步骤的执行顺序和详细信息; 4. 根据查询计划的结果,优化 SQL 语句或数据库结构,以提高查询性能。 在分析查询计划时,可以关注以下几个重要的信息: - 节点类型:描述了执行计划中每个步骤的类型,例如 Seq Scan(顺序扫描)、Index Scan(索引扫描)、Nested Loop(嵌套循环连接)等; - 访问方法:描述了节点类型所使用的具体访问方法,例如使用哪个索引、使用哪种连接算法等; - 过滤条件:描述了节点类型所使用的过滤条件,可以帮助判断是否需要添加索引或优化查询条件; - 排序方式:描述了节点类型所使用的排序方式,可以帮助判断是否需要添加排序索引; - 执行计划的顺序:描述了查询计划中每个步骤的执行顺序,可以帮助判断是否存在性能瓶颈。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值