MySQL中对字段使用函数导致索引失效

avatar 2021年08月24日17:15:27 1 113 views

MySQL中对字段使用函数导致索引失效的问题其实很常见,大家一般都知道,但是工作中还是有很多人会犯错

比如下面这个例子,查询今天提交的订单

很多同学可能会写上面这种,实际上这种写法导致索引失效,最终全表扫描

-- 索引失效
explain select * from oms_order o where date_format( o.SUBMIT_TIME, '%Y-%m-%d' ) = date_format( NOW( ), '%Y-%m-%d' ) 

-- 索引有效
explain select * from oms_order o where  o.SUBMIT_TIME BETWEEN curdate() AND  DATE_SUB(curdate(),INTERVAL -1 DAY)

  • 微信
  • 交流学习,有偿服务
  • weinxin
  • 博客/Java交流群
  • 资源分享,问题解决,技术交流。群号:590480292
  • weinxin
avatar

发表评论

avatar 登录者:匿名
可以匿名评论或者登录后台评论,评论回复后会有邮件通知

  

已通过评论:1   待审核评论数:0
  1. avatar s

    文章写的还可以,我基本上看完了,谢谢分享