为了账号安全,请及时绑定邮箱和手机立即绑定

php分页如何提高效率的问题

php分页如何提高效率的问题

qq_遁去的一_1 2019-04-06 08:32:07
现在写分页时要先算出总的数据条数,然后根据每页多少个,算出一共多少页。也就是写语句的时候如下:$req=date>1200000000先SELECTcount(*)FROMtestWHERE{$req}然后根据这个总条数和每页显示的条数得出$limit再SELECT*FROMtestWHERE{$req}LIMIT{$limit}感觉这样的执行效率不高,请问能不能只SELECT一次呢?
查看完整描述

2 回答

?
暮色呼如

TA贡献1853条经验 获得超9个赞

担心性能的话,可以摒弃"总页数"的话,请参考
yahoo的EfficientPaginationUsingMySQL使用SQL_CALC_FOUND_ROWS,请先阅读
ToSQL_CALC_FOUND_ROWSornottoSQL_...
                            
查看完整回答
反对 回复 2019-04-06
?
慕村225694

TA贡献1880条经验 获得超4个赞

Mysql在做分页带Limit查询的时候,越往后面,效率越低,我说下我自己的做法,一般主键ID都为自增的,且带where条件数据不可能完全都是所要得到的数据。举个例子有一张表we_user_score存积分的表
uid(_pk)username(用户名)score(积分)假设有100条数据其中积分分布为10-100这个区间。这个时候,想要获取score>30的数据每页5条selectuid,username,scorefromwe_user_scorewherescore>30limit0,5;但是在做第二页查询的时候sql就可以这么写selectuid,username,scorefromwe_user_scorewhereuid>=5andscore>30limit5,5;依次类推,这样在大数据量的情况下,速度会提升的比较明显,这应该属于一个小细节吧,呵呵
                            
查看完整回答
反对 回复 2019-04-06
  • 2 回答
  • 0 关注
  • 328 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信