请问为什么两条只是LIMIT不一样的sql语句,查询的差距这么大?

图片描述

索引如下图:
图片描述

我在LIMIT 0,2 时候,无法运行完,会卡死数据库。但LIMIT 0,20就可以很快的查询出来。

阅读 3.4k
2 个回答

走的索引不一样,决定了要检索的数据量多少
1、当你要取的数据很少的时候,mysql认为走start_time的索引很快就能找够满足条件的数据,结果实际上满足条件的数据按照start_time倒序排列需要检索很多数据,所以会比较慢。
2、而当你limit20的时候mysql认为按照其他索引可能需要扫描很多的记录才能找到你要的结果,所以走了city_id的索引。
so这种情况你可以尝试一下按照start_time倒序排列后找两条最近的数据出来,按这些字段的值再去用limit 0,2检索看看是不是很快,如果是的话那就可以确定是这个原因。

当索引的样本数据范围越大,索引的效率越高。当你其他的条件一致的时候,limit的范围可能会引起索引样本的范围限制。--个人理解

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题