• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Mysql 日期型,索引查询的有关问题

mysql 搞代码 7年前 (2018-06-02) 163次浏览 已收录 0个评论

mysql 日期型,索引查询的问题
表中,有一个日期字段WorkDate(Date YYYY-MM-DD格式),现在我把它建成了索引,在检索条件时,WorkDate=’YYYY-MM-DD’ 时,用EXPLAIN分析,能看到使用了索引,但是当我想按月查询时,
写成 WorkDate like ‘YYYY-MM%’
或者 SUBSTR(WorkDate,1,7) = ‘YYYY-MM’ 
或者 DATE_FORMAT(WorkDate,’%Y%m’) = ‘YYYYMM’ 
用EXPLAIN分析的结果是都没有使用索引。。

现在我想实现按月查询也能使用上索引该怎么办呀。。高手指点!!

——解决方案——————–
第二个肯定用不到索引 至于第一个为什么用不到索引是因为mysql考虑走索引比不走索引消耗要高
——解决方案——————–
索引字段操作符左边用函数后不走索引,要走索引可以 WorkDate >=’2012-01-01′ and WorkDate <‘2012-02-01’
——解决方案——————–
列出你的show index from table与explain select …
——解决方案——————–
你对这个字段进行了运算,无法使用索引,查询某月,可以使用

where WorkDate between ‘YYYY-MM-01’ and ‘YYYY-MM-31’

这样就可以使用索引了。
——解决方案——————–
SELECT * from 
TAppointMst
where 
AppDate BETWEEN ‘2012-01-01’ and ‘2012-01-31’
这个查出来有多少记录,如果占了表中所有数据的大部分,全表扫描效率更高,Mysql优化器会自动选择不走索引
——解决方案——————–
你的表中一共 84568 条记录。 而符合条件的记录达到85315? 你提供的数据是准确的吗? 建议在提问时保持一致,比如你的字段名,不要变来变去。

——解决方案——————–
可以试下强制走索引。
SELECT * FROM table USE INDEX(index_name) WHERE …
具体资料可以网上查查


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Mysql 日期型,索引查询的有关问题
喜欢 (1)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址