Mysql中between...and引起的索引失效问题及解决

 更新时间:2023年07月28日 10:27:35   作者:等待中的小码农  
这篇文章主要介绍了Mysql中between...and引起的索引失效问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

发生场景

在查询学生表的时候,需要支持根据创建时间来筛选出某段时间内入学的学生总数,因此在创建时间上加了索引,但是最终发现还是会走全量查询。

实验过程

CREATE TABLE `t_user` (
  `id` bigint(11) unsigned NOT NULL COMMENT '学生id',
  `name` varchar(24) NOT NULL COMMENT '学生名称',
  `createTime` dat NOT NULL COMMENT '创建时间',
  PRIMARY KEY (`id`),
  KEY `index_updateTime` (`createTime`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
select count(1) from t_user where createTime between '2022-08-30' and '2022-08-31';

使用insert语句插入3万多条数据后,其中30号至31号之前有9千多条数据,发现查询的时候并没有走到索引。

结果如下:

在这里插入图片描述

缩小查询区间,只查31号的(4千多条数据),却发现可以走到索引了,

结果如下:

select count(1) from t_user where createTime between '2022-08-31' and '2022-08-31';

在这里插入图片描述

再找一个数据量为5千的区间来试一下,也是会走到索引的,

结果如下:

select count(1) from t_user where createTime between '2022-08-23' and '2022-08-25';

在这里插入图片描述

没走到索引是因为between…and引起的吗?如果改为>=和<=呢。

结果如下:

select count(1) from t_user where createTime >= '2022-08-30' and createTime  <= '2022-08-31';

在这里插入图片描述

结论

经过实验发现,当查询的数据量达到6千(占比20%左右),就不走索引了。

引起原因:

表的数据量太大,会让数据库中的优化器进行处理。

优化器是在表里面有多个索引的时候,决定使用哪个索引,查询的量太大,导致优化器认为走全表查询时间效率更佳。

但是如果一定要用到区间查询,这个问题该如何解决呢?

方案一

select count(1) from t_user where createTime between '2022-08-30' and '2022-08-31' limit 1;

在这里插入图片描述

方案二

select count(1) from t_user FORCE INDEX(index_updateTime) where createTime between '2022-08-30' and '2022-08-31';

在这里插入图片描述

思考:

当查询数据量达到一定量的时候会导致between…and索引失效,那分页查询的时候呢?

select id,name, createTime from t_user where createTime between '2022-08-30' and '2022-08-31' limit 1,500;

在这里插入图片描述

可见,查询第一页的时候索引有效,但是随着页码越来越大的时候,索引却失效了,

select id,name, createTime from t_user where createTime between '2022-08-30' and '2022-08-31' limit 100000,500;

在这里插入图片描述

因此,遇到这种因查询数据量过大而导致的索引失效的问题,需要对其功能做相应限制处理。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SELECT INTO 和 INSERT INTO SELECT 两种表复制语句简单介绍

    SELECT INTO 和 INSERT INTO SELECT 两种表复制语句简单介绍

    Insert是T-sql中常用语句,Insert INTO table(field1,field2,...) values(value1,value2,...)这种形式的在应用程序开发中必不可少
    2012-11-11
  • MySQL一些常用高级SQL语句详解

    MySQL一些常用高级SQL语句详解

    对 MySQL 数据库的查询,除了基本的查询外,有时候需要对查询的结果集进行处理。例如只取 10 条数据、对查询结果进行排序或分组等等,今天就给大家分享MySQL一些常用高级SQL语句,感兴趣的朋友一起看看吧
    2022-06-06
  • Linux/Mac MySQL忘记密码命令行修改密码的方法

    Linux/Mac MySQL忘记密码命令行修改密码的方法

    这篇文章主要介绍了Linux/Mac MySQL忘记密码命令行修改密码的方法,需要的朋友可以参考下
    2017-05-05
  • MySQL约束类型及举例介绍

    MySQL约束类型及举例介绍

    今天小编就为大家分享一篇关于MySQL约束类型及介绍的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10
  • 简单了解mysql InnoDB MyISAM相关区别

    简单了解mysql InnoDB MyISAM相关区别

    这篇文章主要介绍了简单了解mysql InnoDB MyISAM相关区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Mysql的Table doesn't exist问题及解决

    Mysql的Table doesn't exist问题及解决

    这篇文章主要介绍了Mysql的Table doesn't exist问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • SQL如何获取目标时间点或日期的方法实例

    SQL如何获取目标时间点或日期的方法实例

    日期获取在我们日常开发中经常会遇到,这篇文章主要给大家介绍了关于SQL如何获取目标时间点或日期的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • 详解mysql8.018在linux上安装与配置过程

    详解mysql8.018在linux上安装与配置过程

    这篇文章主要介绍了mysql8.018在linux上安装与配置过程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • MySQL json相关函数及功能详解

    MySQL json相关函数及功能详解

    MySQL提供了一系列的JSON函数,用于解析、提取、修改和操作JSON数据,以下是一些常用的JSON函数及其功能,需要的朋友可以参考下
    2023-11-11
  • Ubuntu上安装MySQL+问题处理+安全优化

    Ubuntu上安装MySQL+问题处理+安全优化

    这篇文章主要汇总介绍了Ubuntu上安装MySQL+问题处理+安全优化的相关事项,非常的细致全面,有需要的小伙伴可以参考下
    2016-03-03

最新评论