首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Postgresql索引设计:组合索引排序

Postgresql索引设计:组合索引排序
EN

Stack Overflow用户
提问于 2016-08-22 21:03:03
回答 1查看 53关注 0票数 0

我知道如果我有两个查询,比如:

代码语言:javascript
复制
SELECT * FROM fruits WHERE type='apple'

代码语言:javascript
复制
SELECT * FROM fruits WHERE type='orange' AND state='rotten'

那么一个有效的索引应该是:

代码语言:javascript
复制
CREATE INDEX type_state_index_on_fruits ON fruits(type, state) USING btree;

因为它将能够对第一个和第二个查询使用索引。

但是,如果要进行排序,会发生什么:

代码语言:javascript
复制
SELECT * FROM fruits WHERE type='orange' AND state='rotten' ORDER BY picked_at ASC

我是否可以有效地创建按picket_at排序的类型和状态的有序索引,这样在这两种情况下,数据库都不必在获取行后进行排序:

代码语言:javascript
复制
SELECT * FROM fruits WHERE type='apple' ORDER BY picked_at ASC
SELECT * FROM fruits WHERE type='orange' AND state='rotten' ORDER BY picked_at ASC
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-08-23 02:37:55

如果您希望两个查询都使用一个索引,我建议您在(type, picked_at)上使用一个。

如果需要在索引中包含state,则可能需要两个索引。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39080312

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档