我知道如果我有两个查询,比如:
SELECT * FROM fruits WHERE type='apple'和
SELECT * FROM fruits WHERE type='orange' AND state='rotten'那么一个有效的索引应该是:
CREATE INDEX type_state_index_on_fruits ON fruits(type, state) USING btree;因为它将能够对第一个和第二个查询使用索引。
但是,如果要进行排序,会发生什么:
SELECT * FROM fruits WHERE type='orange' AND state='rotten' ORDER BY picked_at ASC我是否可以有效地创建按picket_at排序的类型和状态的有序索引,这样在这两种情况下,数据库都不必在获取行后进行排序:
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发布于 2016-08-23 02:37:55
如果您希望两个查询都使用一个索引,我建议您在(type, picked_at)上使用一个。
如果需要在索引中包含state,则可能需要两个索引。
https://stackoverflow.com/questions/39080312
复制相似问题