问题:
八张数据库表连接查询,四张表有索引,四张表未用索引,一个sql文检索出所有的数据,速度非常慢,需要进行优化。
解决思路:
实在是不能加索引的情况下,想办法把多张表做成一个临时表进行检索(即 复杂查询考虑拆分为几个简单查询。可使用Map实现关联)。
首先是进行主表和和主表关联的表的查询,做成Map集合,key值为主表和无索引表的连接的条件值,value值为该条件下对应的数据结果;其次检索无索引表,做成Map集合,key为表连接条件,value为对应结果,通过循环主表数据连接子表数据结果。
检索速度已验证,1000条数据下不做优化页面渲染显示需要20-25s,优化后只需0.8-1.3s。其中修改了一张无索引表,将其主要数据放入了相关有索引表中,提升了一部分检索速度,当然也有网速的部分原因,但是检索速度确实是提升了许多。
总结:正确的索引(索引字段,索引类型),合适的分表,大型的sql拆分为多个小sql查询,等等。优化手段不只一种。
推荐一篇文章:《高性能MySQL》读书笔记--查询性能优化
版权声明:本文为a_starry_sky原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。