mysql使用时间字段索引

Posted 劈天造陆

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql使用时间字段索引相关的知识,希望对你有一定的参考价值。

索引可以提高查询效率,平时按照时间查询经常遇到,所以就会给时间添加索引,但是添加索引怎么用呢?

首先创建一张表test_table

然后给时间字段创建索引

 

 导入大量数据,可以使用存储过程

查看一下表中数据条数

 

 一共78W数据,我们用平常的sql查询2019-12-30号当天的数据

SELECT * FROM test_table WHERE DATE_FORMAT(create_time,"%Y-%m-%d") >= \'2019-12-30\'

 

 一共891条数据,耗时400ms左右

用EXPLAIN查看一下sql是否使用到索引

 

 这是因为使用函数时,索引会失效

用下面这种方式就可以使用索引

SELECT * FROM test_table WHERE create_time >= str_to_date(\'2019-12-30\', \'%Y-%m-%d\')

 

 耗时30ms左右,效率提升了10倍

用EXPLAIN查看一下sql

 

 这样就用到了时间索引

 

以上是关于mysql使用时间字段索引的主要内容,如果未能解决你的问题,请参考以下文章

为啥mysql解释说'使用索引'而使用的索引不包含必填字段

日期时间字段上的 MySQL 索引不是 RANGE 类型,而是使用 INDEX 类型

Solr Highlighting:如何为同一字段请求多个片段长度?

如何在 MySQL 中使用 LIKE 和部分匹配的 VARCHAR 字段的索引?

MySQL索引和字段类型,字段长度

何时在 SQL 表字段 (MySQL) 上添加索引?