扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
1)这种框架自带的分页方法,有时候数据量一多就会比较慢,所以一定要自己些查询sql语句。 我在项目中就遇到一个这样的问题,两个表关联分页查询,因为我使用的是inner join进行的关联,导致仅有43万的数据,查询了5秒多,后改为left join,用时1.2秒!
根据查看执行计划,对查询条件添加对应的索引!
如果你知道查出来的数据的条数,就可以使用limit numb; 我在项目中遇到了一个问题,两个表关联查询,因为数据量很大,所以查询速度很慢,但是我知道只会查出一条数据,我就使用了 select * from table where code = xxxx limit 1; 速度仅用了不到1秒;
框架的分页查询,必然会有count查询,因为他要计算总页数,但是这样有时候会导致查询比较慢。我们可以和前端约定好,不展示页码,只保留上一页和下一页。这样我们就可以通过计算页码的起始位置和结束位置来自己分页查询了。
举例:
// 获取起始位置
publicstaticIntegergetStartIndex(Integer pageNo,Integer pageSize){
return(pageNo -1) * pageSize;
}
sql: select * from table limit startIndex, pageSize;
所以,我们在解决问题时候,要根据不同的业务场景,使用不同的办法解决。如果使用了分页还是慢的话,就要查看自己的MySQL语句是否有问题!通过查看执行计划进行分析。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流