postgresql获取真正的execution plan

analyze会真正执行,除了select语句,最好放在一个事务中运行,然后rollback.

BEGIN;

EXPLAIN ANALYZE UPDATE ...;

ROLLBACK;

常用方式如下:

EXPLAIN (ANALYZE, BUFFERS, TIMING) SELECT ...;

sql 复制代码
ccc=# select * from t1;
 id | name 
----+------
  1 | aaa
  2 | bbb
  3 | ccc
  4 | ddd
(4 rows)

ccc=# begin;
BEGIN
ccc=*# EXPLAIN (ANALYZE, BUFFERS, TIMING) update t1 set name='yyy' where id=3;
                                              QUERY PLAN                                               
-------------------------------------------------------------------------------------------------------
 Update on t1  (cost=0.00..21.25 rows=0 width=0) (actual time=0.113..0.114 rows=0.00 loops=1)
   Buffers: shared hit=3 dirtied=1
   ->  Seq Scan on t1  (cost=0.00..21.25 rows=4 width=64) (actual time=0.012..0.014 rows=1.00 loops=1)
         Filter: (id = 3)
         Rows Removed by Filter: 3
         Buffers: shared hit=1
 Planning:
   Buffers: shared hit=3 read=6
 Planning Time: 2.737 ms
 Execution Time: 2.241 ms
(10 rows)

ccc=*# rollback;
ROLLBACK
ccc=# select * from t1;
 id | name 
----+------
  1 | aaa
  2 | bbb
  3 | ccc
  4 | ddd
(4 rows)

ccc=#

调试执行计划时可以临时enable/disable一些选项,详细列表见:

https://www.postgresql.org/docs/current/runtime-config-query.html

-- Plan with nested loop allowed (default)

EXPLAIN (ANALYZE, FORMAT JSON)

SELECT ... ;

-- Compare with nested loop discouraged

BEGIN;

SET LOCAL enable_nestloop = off;

EXPLAIN (ANALYZE, FORMAT JSON)

SELECT ... ;

COMMIT;

相关推荐
秋95 分钟前
windows中安装redis
数据库·redis·缓存
Cosolar26 分钟前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
想唱rap34 分钟前
IO多路转接之poll
服务器·开发语言·数据库·c++
SeaTunnel42 分钟前
AI 让 SeaTunnel 读源码和调试过时了吗?
大数据·数据库·人工智能·apache·seatunnel·数据同步
凯瑟琳.奥古斯特1 小时前
数据冗余与规范化的本质[数据库原理]
开发语言·数据库·职场和发展
_ku_ku_2 小时前
数据库系统原理 · SQL 数据定义、更新及数据库编程 · 自学总结
数据库·oracle
Mortalbreeze2 小时前
深度理解文件系统 ---- 从磁盘存储到内核存储
大数据·linux·数据库
2301_803934612 小时前
MySQL 字段类型选择规范指南
jvm·数据库·python
oddsand13 小时前
Redis网络模型
java·数据库·redis
皮卡祺q3 小时前
【redies0-导论】分布式系统的演进-引进redis原因
java·数据库·redis