我想知道以下内容在性能上是否有区别
SELECT ... FROM ... WHERE someFIELD IN(1,2,3,4)
SELECT ... FROM ... WHERE someFIELD between 0 AND 5
SELECT ... FROM ... WHERE someFIELD = 1 OR someFIELD = 2 OR someFIELD = 3 ...
或者MySQL会像编译器优化代码一样优化SQL吗?
EDIT
根据评论中说明的原因,将AND改为OR。
我敢打赌它们是一样的,你可以通过执行以下操作来运行测试:
循环遍历“in(1,2,3,4)”500次,看看需要多长时间。循环“=1 or= 2 or=3…”版本500次,看看它运行了多长时间。
你也可以尝试一个连接的方式,如果someField是一个索引,你的表很大,它可以更快…
SELECT ...
FROM ...
INNER JOIN (SELECT 1 as newField UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4) dt ON someFIELD =newField
我在我的SQL Server上尝试了上面的join方法,它几乎与in(1,2,3,4)相同,它们都导致了一个聚集索引查找。我不确定MySQL将如何处理它们。