MySQL5.6 ORDER BY主键id加LIMIT限制走错索引

发现问题:

最近后台有一个列表查询功能,今年数据量起来后,导致数据库 慢查询,导致线上服务器直接504。

这其中涉及到一个大表,主键id;在查询时候使用了 order by id desc limit 20,explain发现接近全表扫描了。

围绕这个问题,逐步修改语句优化,发现去掉 status条件或者 忽略 status索引,即可。 

但是,这个又是远古遗留问题,status索引理应不建立(吐槽以前的小伙伴),如今又不能手动去掉。

可以选择如下解决方案:

1、去掉where status 条件 (不太合适)

2、ignore index(status) 索引条件 (Model层面不好改动)

上面两个解决方案,无法实施以后,求助于网络,发现解决方案,参考如下:

https://blog.csdn.net/gycyxh/article/details/89918261

https://www.jianshu.com/p/caf5818eca81

最终解决方案:

1、sql去掉limit 部分;使用程序去处理多条返回值

2、换用其他 字段作为order by ,比如日期时间。(最优)

成功解决,优化成功。

至于其中原理,还需要参考具体文章详解。

参考总结如下:

总结

  • 在order by id的情况下,MySQL由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引;
  • order by 和 limit 结合使用,如果where 字段,order by字段都是索引,那么有limit索引会使用order by字段所在的索引,没有limit会使用where 条件的索引;
  • 对于数据量比较大,而且执行量很高的分页sql,尽可能将所有的查询字段包括在索引中,同时使用索引来消除排序;
  • 多用explain查看是否使用到了最优索引;
  • 利用optimizer trace查看优化器执行过程;
  • 观察mysql的slow_query_log,及时做排查优化。
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:根据引用内容中的描述,MySQL的子查询中order by语句可能会导致索引失效。在MySQL 5.7之后,为了解决这个问题,需要在子查询中limit限制。然而,即使入了limit,仍然可能会使用filesort,导致子查询无效。因此,使用子查询进行order by操作可能会遇到问题。\[1\] 引用\[2\]:在MySQL中,建立索引是非常重要的。常见的问题之一是询问什么情况下索引会失效。一般来说,索引失效可能是因为没有遵守B+树的最左原则。此外,即使按照最左原则建立了索引,有时也会遇到使用order by时走索引和不走索引的情况。\[2\] 引用\[3\]:根据引用内容中的描述,当查询字段为'*'时,MySQL可能会选择全表扫描而不走索引。这是因为当查询字段为'*'时,MySQL需要进行回表查询,即在返回之前还需要进行多次回表操作。然而,如果查询字段为对应的索引字段,MySQL可以直接通过索引拿到对应的返回字段,不需要进行回表操作,从而提高查询速度。此外,B+树的叶子节点已经排好序,也不需要进行排序操作,进一步提高了查询效率。因此,当查询字段为对应索引字段时,MySQL会选择走索引。\[3\] 综上所述,当使用order by时,MySQL索引可能会失效。这可能是因为子查询中order by导致索引失效,或者查询字段为'*'时MySQL选择全表扫描而不走索引。在实际使用中,需要注意这些情况,合理设计索引和查询语句,以提高查询效率。 #### 引用[.reference_title] - *1* [MySQLorder by不使用索引的解决办法](https://blog.csdn.net/weixin_38238552/article/details/102530479)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [什么情况下mysql使用order by不会走索引?](https://blog.csdn.net/qq_38258642/article/details/129035223)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值