索引可以提高查询效率,平时按照时间查询经常遇到,所以就会给时间添加索引,但是添加索引怎么用呢?
首先创建一张表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
这样就用到了时间索引