一次sqlite执行select慢的排查记录

环境:sqlite3,嵌入式设备,假设表名为my_table,数据量不大,一般也就几千,多的时候也就几万条,查询语句:select * from my_table order by (startTime +0) DESC limit 0,100;

问题:该语句以startTime排序,并使用limit限制排序后的0到100行的结果,在嵌入式设备上测试查询耗时需要几秒。

排查:

将表导入到windows上,使用SQLiteStudio(或者其它工具都可以)打开,然后执行相同的语句,发现只需要100多毫秒。因为嵌入式设备和pc主机的性能差距,且现场环境的程序还有其它资源开销,肯定是不能完全复现出几秒的耗时。那就多造点数据,把数据造到60w条后,再执行select * from my_table order by (startTime +0) DESC limit 0,100;测试:

发现耗时达到了300多毫秒,这样即使在windows下也有很大优化的空间,那就基于这个样本数据在windows下进行优化测试。

在sql语句前加上EXPLAIN QUERY PLAN,也就是EXPLAIN QUERY PLAN select * from t_event order by (startTime+0) DESC limit 0,100;

可以看到遍历了整个表,也就是没有走索引,那我加上索引startTime后再测试,发现还是这样。到这里startTime+0引起了我的注意,这里+0的原因,是因为startTime是text类型,+0可以将其转换成整型,但是startTime就是时间戳,只是类型为text,没有必要转换成整型就能排序, 删掉startTime后的"+0"试试:

可以看到走了索引。

那我们再执行select * from my_table order by startTime DESC limit 0,100;测试一下:

速度由340多毫秒优化到了13豪秒!

最后在嵌入式设备上同样修改后,执行速度从3~4秒优化到到30毫秒左右,将近100倍的提升。

总结:

1.针对具体场景建立合适的索引;

2.使用EXPLAIN 和 EXPLAIN QUERY PLAN 来分析查询计划和性能;

3.对于可以使用整型的列,尽量使用整型;

4.对索引字段额外的操作可能导致索引失效,比如"+0",需要测试确认

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值