首页 > 数据库 > mysql教程 > MySQL优化Limit分页_MySQL

MySQL优化Limit分页_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 13:31:21
原创
1084 人浏览过

bitsCN.com

MySQL优化Limit分页

 

   很多时候、我们需要选择出从指定位置开始的指定行数、此时、limit笑了

     对于limit的定义是:

     limit x,y

     表示从第x行开始选择y条记录

     

     在业务需要分页操作的时候、我们通常采用limit+order by这对洗剪吹组合、高端洋气上档次

     然而、当翻到非常靠后的页面时、MySQL需要花费大量的时间来扫描需要丢弃的数据

     

     此时比较好的策略是使用延迟关联:

     通过使用覆盖索引查询返回需要的主键、再根据这些主键关联原表获得需要的行

     具体请看下面的一个例子

     

     假如有这样一个查询:

[plain] select film_id,actor,description from film where actor='WaterBin' order by title limit 100000,5  
登录后复制

我们可以这样改造:

[plain] 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);  
登录后复制

 

 

bitsCN.com
相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
git - 怎么查push记录 不是commit的记录
来自于 1970-01-01 08:00:00
0
0
0
laravel - laravle Eloquent ORM 一次update多条记录
来自于 1970-01-01 08:00:00
0
0
0
php - 记录视频上次观看时间
来自于 1970-01-01 08:00:00
0
0
0
Nginx proxy_pass如何记录response?
来自于 1970-01-01 08:00:00
0
0
0
显示某条记录的某个字段(node.js+mongodb)
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板