我需要这方面的帮助。我有这样的查询:
SELECT * FROM cart WHERE
(ts_in between 1249077600 AND 1318975199);
上面的查询在 ts_in 列(范围类型)上使用 btree 索引。现在我想为此添加另一个标准。例如:
SELECT * FROM cart WHERE
(ts_in between 1249077600 AND 1318975199) and is_removed=0;
上面的查询没有在 ts_in 列(范围)上使用 btree 索引。
有人能告诉我为什么以及我怎样才能以正确的方式进行快速计算。
我创建了两个用于测试的索引:
CREATE INDEX range_idx_1 using BTREE
ON cart (is_removed, ts_in);
和
CREATE INDEX range_idx_2 using BTREE
ON cart (ts_in , is_removed);
有趣的是,当我使用这个查询时:
EXPLAIN SELECT id FROM cart WHERE
(ts_in between 1249077600 AND 1318975199) AND is_removed=0;
我收到了这个结果:
id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra
1 | SIMPLE | cart | range | range_idx_1,range_idx_2 | range_idx_1 | 6 | | 17391 | Using where; Using index
上面的查询使用了索引但是:
EXPLAIN SELECT * FROM cart WHERE
(ts_in between 1249077600 AND 1318975199) AND is_removed=0;
我有这样的结果:
id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra
1 | SIMPLE | cart | ref | range_idx_1,range_idx_2 | range_idx_1 | 1 | const | 77979 | Using where
这不使用索引。
当我尝试使用 USE INDEX 或 FORCE INDEX 语法时,结果是一样的。在一种情况下,Mysql 不使用索引。有什么帮助吗?
最佳答案
运行一个
EXPLAIN SELECT * FROM cart WHERE
(ts_in between 1249077600 AND 1318975199) and is_removed=0;
看看为什么mysql查询优化器选择了不同的索引。
Mysql 本身并不擅长组合索引,因此您可能需要为该查询使用组合索引。尝试为 is_removed, ts_in
添加索引(btree?)(按此顺序!)。
您还可以通过在查询中添加一个 USE INDEX 来强制 mysql 使用您的索引。有时这会作为查询优化器选择的索引提供更好的结果:
SELECT * FROM cart USE INDEX '<idx_name>' WHERE
(ts_in between 1249077600 AND 1318975199) and is_removed=0;
关于mysql - 将索引与范围类型查询和其他条件一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7803627/