Postgresql聚簇索引cluster使用说明
2022/1/12 19:34:06
本文主要是介绍Postgresql聚簇索引cluster使用说明,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
- 基于test_id_idx来聚簇public.test表数据
CLUSTER public.test USING test_id_idx; CLUSTER public.test; -- 自动执行上次的聚簇
官方手册:http://postgres.cn/docs/9.6/sql-cluster.html
-
使用场景
参考以下例子,SQL执行计划
-- sql语句大概是 select xxx,count(*) from test where id < 317 and id > 0 group by xxx -- 执行计划一部分如下: -> Bitmap Heap Scan on test (cost=26785.44..49868.47 rows=7141 width=222) (actual time=1113.964..3513.711 rows=50849 loops=1) Recheck Cond: ((id < 317) AND (id > 0)) Heap Blocks: exact=50616 Buffers: shared hit=33 read=62433 written=23
如上Bitmap扫描出exact=50616个block(id < 317 and id > 0 这个条件匹配到50616分block),随机扫描的block太多导致sql性能非常低。
针对该场景我们可以让test表基于id字段顺序分布在磁盘中,这样可以大大减少扫描的block。
CLUSTER public.test USING test_id_idx;
执行上面这个sql可以让id < 317的数据顺序分布在磁盘中,大大减低执行sql是扫描的block,提高查询性能
这篇关于Postgresql聚簇索引cluster使用说明的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用