但是要注意的是~你执行
b= 2 and a =1
也是能匹配到索引的,因为Mysql有优化器会自动调整a,b的顺序与索引顺序一致。
相反的,你执行
b = 2
就匹配不到索引了。...在执行sql的时候,优化器会 帮我们调整where后a,b,c的顺序,让我们用上索引。...如果你建立的是(a,b)索引,那么只有a字段能用得上索引,毕竟最左匹配原则遇到范围查询就停止匹配。...如果对(b,a)建立索引那么两个字段都能用上,优化器会帮我们调整where后a,b的顺序,让我们用上索引。...总结
尽可能将范围查询转换成“等值”查询,如 “a>1 and a10” 可以写成“a in (1,2,3,4,5) and b > 10”,然后设置索引为 idx(a,b)。