Query1. SELECT * FROM traffic WHERE id IN (1904817,1904699,1882859);
Query2. SELECT * FROM traffic WHERE id IN
(SELECT id FROM data_table where condition=1);
这里的流量表有近百万条记录,id
为主键。
查询 1 使用索引 id
在 Query2 中它没有使用索引。
如何有效地运行 Query2...通过使用索引...
最佳答案
使用inner join
代替IN
并在条件列
上创建另一个索引:
select t.* from traffic t
inner join data_table d on t.id = d.id and d.contition = 1
关于mysql - 如何强制 Mysql 在 IN 子句中使用主索引...?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10615839/