一直来,系统中总有几百万的数据,变态的QA总是要测试几十万页的翻页。对于Mysql来说,翻到几十万页之后,常规的查询的肯定会慢了。还好用户不会这样去用。只有QA才会提这种‘无礼’的要求。
对于查询:
select * from table limit 1000000,20
当然会慢得不行了。
现在终于发现了,还可以这样改写:
select * from table a,(select id from table limit 1000000,20) b where a.id=b.id
这样就快得不是一点半点了。以前真是笨了^_^
看来,使用MySQL,还是得多动动脑筋来重写SQL来改善查询性能的。
本文介绍了一种通过重写SQL查询来显著提高MySQL翻页效率的方法。针对大量数据的翻页查询,传统的LIMIT方法会导致性能下降。通过使用子查询的方式,可以有效地解决这一问题。
1271

被折叠的 条评论
为什么被折叠?



