> 백엔드 개발 > PHP 튜토리얼 > mysql - 用php数组的array_slice分页和用limit查询分页哪个效率更高?

mysql - 用php数组的array_slice分页和用limit查询分页哪个效率更高?

WBOY
풀어 주다: 2016-06-06 20:29:22
원래의
1710명이 탐색했습니다.

以前一直用的limit来分页,现在发现array_slice分页挺好用的,就是不知道效率会不会太低

回复内容:

以前一直用的limit来分页,现在发现array_slice分页挺好用的,就是不知道效率会不会太低

sql:select * from 表 limit m offset n.

这是正常的翻页的业务需求.

在一张count为200w的表上执行一下sql:
select * from 表 limit 1000000,5

执行时间:25s

问题:
MySQL里对LIMIT OFFSET的处理方式是,取出OFFSET+LIMIT的所有数据,然后去掉OFFSET,返回底部的LIMIT。
这种方式在offset很高的情况下,如:limit 100000,20,这样系统会查询100020条,然后把前面的100000条都扔掉,这是开销很大的操作,导致慢查询很慢.

如何优化:

  1. 用id>m limit n 取代,比用 limit m,n 快很多,原因在于与利用上了主键索引, 只查询了n条记录. 这种方法很适合数据加载,但是不一定适合前台的翻页场景,
    因为ID可能不连续, 在电梯模式的翻页中不适用,只是用扶梯模式的翻页。
    select * from 表 where id > 1000000 limit 5
    执行一下:0.013s

还有一个简单的优化办法是使用覆盖查询(covering index)查询,然后再跟全行的做join操作。这样可以直接使用index得到数据,而不去查询表,当找到需要的数据之后,在与全表join,获得其他的列。
如:
select * from 表 inner join (select id from 表 limit 1000000,5) as lim on 表.id = lim.id

执行时间:0.211s

array_slice 分页?你确定要全部查出来在服务器分页,而不是在数据库中查询某一页的数据

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿