现在写分页时要先算出总的数据条数,然后根据每页多少个,算出一共多少页。
也就是写语句的时候如下:
先
然后根据这个总条数和每页显示的条数得出$limit
再
感觉这样的执行效率不高,请问能不能只SELECT一次呢?
Mysql 在做分页带Limit查询的时候,越往后面,效率越低,我说下我自己的做法,一般主键ID都为自增的,且带where条件数据不可能完全都是所要得到的数据。 举个例子 有一张表 we_user_score 存积分的表uid(_pk) username(用户名) score(积分)
假设有100条数据 其中积分分布为10-100这个区间。这个时候,想要获取score>30的数据 每页5条
select uid,username,score from we_user_score where score>30 limit 0,5;
但是在做第二页查询的时候 sql就可以这么写
select uid,username,score from we_user_score where uid>=5 and score>30 limit 5,5;
依次类推,这样在大数据量的情况下,速度会提升的比较明显。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。