标签:Postgresql 聚簇 317 public cluster sql test id block
- 基于test_id_idx来聚簇public.test表数据
CLUSTER public.test USING test_id_idx;
CLUSTER public.test; -- 自动执行上次的聚簇
-
使用场景
参考以下例子,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,聚簇,317,public,cluster,sql,test,id,block 来源: https://www.cnblogs.com/JaminXie/p/15793720.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。