mysql 时间 between查询 索引吗_Mysql: mysql between 日期索引 索引问题-日期索引使用...

Mysql: mysql between 日期索引 索引问题-日期索引使用

表结构:

dep_date

dep

arr

联合索引: ind_coll_date_route  (dep_date ,dep,arr)

这两天发现原来的查询效率慢了,使用explain 查看,居然没有使用索引,

我的索引是日期类型的,首先想到的是mysql对日期类型的索引的处理机制是不是不同,在where条件里试了几种,发现效果都差不多,

where dep_date >= ‘20161121’

where dep_date  >= ‘2016-11-21’

where dep_date  between ‘2016-11-01’ and ‘2016-11-21’

还有各种函数,最后发现结论都是一样的,在baidu上查询也没有有价值的内容。

最后发现了一些规律,但不知道是否有普遍性,即:

在查询数据条数约占总条数五分之一以下时能够使用到索引,但超过五分之一时,则使用全表扫描了。

试了多张表,均是这个结论, 所以想这个五分之一应该是在某一个地方设置的,或者是系统默认在查询优化时的一个经验值,在以后的处理的进修引起注意。

解决办法:

强制走索引

SELECT *

FROM `table_xxx`

FORCE INDEX ( ind_coll_date_route )

WHERE

dep_date

BETWEEN ‘2017-12-01‘

AND ‘2017-12-30‘

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中的不等于操作符(!=和<>)在某些情况下可能会导致查询不走索引。这是因为MySQL优化器在执行查询计划时会根据不同的条件和索引选择最优的执行方式。在一些特定情况下,使用不等于操作符可能会导致MySQL优化器决定不使用索引。 具体而言,不等于操作符在以下情况下可能不走索引- 使用!=和<>进行不等于查询- 使用not in和not exists进行不等于查询- 在建立索引和没有索引的字段上使用like后缀查询,如'%string'。 -索引字段上使用or操作符。 - 使用>、<、<=、>=符号进行比较,可能不走索引,这要取决于优化器的判断。 - 字符串类型字段与数字进行比较,可能不走索引。 综上所述,MySQL中的不等于操作符可能导致查询不走索引。因此,在编写查询语句时,应该考虑使用其他比较操作符或重构查询语句,以便优化查询性能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [mysql之不走索引和sql优化](https://blog.csdn.net/qq_42488996/article/details/109727791)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mysql强制走索引](https://blog.csdn.net/qq_36763236/article/details/125790061)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值