mysql使用时间字段索引

achiverhai 2019-12-30

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

首先创建一张表test_table

mysql使用时间字段索引

然后给时间字段创建索引

mysql使用时间字段索引

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

查看一下表中数据条数

mysql使用时间字段索引

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

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

mysql使用时间字段索引

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

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

mysql使用时间字段索引

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

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

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

mysql使用时间字段索引

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

用EXPLAIN查看一下sql

mysql使用时间字段索引

 这样就用到了时间索引

相关推荐