MySQL 优化Limit分页

WBOY
풀어 주다: 2016-06-07 16:38:46
원래의
792명이 탐색했습니다.

很多时候、我们需要选择出从指定位置开始的指定行数、此时、limit笑了 ? ? ?对于limit的定义是: ? ? ?limit x,y ? ? ?表示从第x行开始选择y条记录 ? ? ? ? ? ?在业务需要分页操作的时候、我们通常采用limit+order by这对洗剪吹组合、高端洋气上档次 ? ? ?然

很多时候、我们需要选择出从指定位置开始的指定行数、此时、limit笑了
? ? ?对于limit的定义是:
? ? ?limit x,y
? ? ?表示从第x行开始选择y条记录
? ? ?
? ? ?在业务需要分页操作的时候、我们通常采用limit+order by这对洗剪吹组合、高端洋气上档次
? ? ?然而、当翻到非常靠后的页面时、MySQL需要花费大量的时间来扫描需要丢弃的数据
? ? ?
? ? ?此时比较好的策略是使用 延迟关联
? ? ?通过使用覆盖索引查询返回需要的主键、再根据这些主键关联原表获得需要的行
? ? ?具体请看下面的一个例子
? ? ?

? ? ?假如有这样一个查询:

select film_id,actor,description from film where actor='WaterBin' order by title limit 100000,5
로그인 후 복사

? ? ?我们可以这样改造:

select film.film_id,film.actor,film.description
  from film
inner join (
select film_id from film where f.actor='WaterBin'
 order by title limit 100000,5
           )
as f using(film_id);
로그인 후 복사



By DBA_WaterBin

2013-08-02

Good Luck

作者:linwaterbin 发表于2013-8-2 21:04:42 原文链接

阅读:104 评论:0 查看评论

MySQL 优化Limit分页

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