开发者社区> 问答> 正文

请教各位大神php分页如何提高效率?

现在写分页时要先算出总的数据条数,然后根据每页多少个,算出一共多少页。
也就是写语句的时候如下:
screenshot
screenshot
然后根据这个总条数和每页显示的条数得出$limit
screenshot

感觉这样的执行效率不高,请问能不能只SELECT一次呢?

展开
收起
落地花开啦 2016-06-13 14:59:46 1842 0
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    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;

    依次类推,这样在大数据量的情况下,速度会提升的比较明显。

    2019-07-17 19:36:04
    赞同 展开评论 打赏
问答分类:
PHP
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战-高驰涛 立即下载
PHP安全开发:从白帽角度做安全 立即下载
PHP 2017.北京 全球开发者大会——高可用的PHP 立即下载