MySQL实现分页-基于limit方式

Posted 梦想一步登天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL实现分页-基于limit方式相关的知识,希望对你有一定的参考价值。

一、limit 基本实现方式

一般情况下,客户端通过传递 pageNo(页码)、pageSize(每页条数)两个参数去分页查询数据库中的数据,在数据量较小(元组百/千级)时使用 mysql自带的 limit 来解决这个问题:

1 收到客户端{pageNo:1,pagesize:10} 
2 select * from table limit (pageNo-1) * pageSize, pageSize;
3 
4 收到客户端{pageNo:5,pageSize:30} 
5 select * from table limit (pageNo-1) * pageSize,pageSize;

 

二、建立主键或者唯一索引

在数据量较小的时候简单的使用 limit 进行数据分页在性能上面不会有明显的缓慢,但是数据量达到了 万级到百万级sql语句的性能将会影响数据的返回。这时需要利用主键或者唯一索引进行数据分页;

1 假设主键或者唯一索引为 good_id 
2 收到客户端{pageNo:5,pagesize:10} 
3 select * from table where good_id > (pageNo-1) * pageSize limit pageSize; 
4 –返回good_id为40到50之间的数据

 

三、基于数据再排序

当需要返回的信息为顺序或者倒序时,对上面的语句基于数据再排序。order by ASC/DESC 顺序或倒序 默认为顺序

select * from table where good_id > (pageNo-1)*pageSize order by good_id limit pageSize; 
–返回good_id为40到50之间的数据,数据依据good_id顺序排列

 

四、分页最佳方案

 1 每页显示10条:
 2 当前 118 120125
 3 
 4 倒序:
 5             大      小
 6             980    970  7 6  6 5  54  43  32
 7 
 8 21 19 98     
 9 下一页:
10 
11     select 
12         * 
13     from 
14         tb1 
15     where 
16         nid < (select nid from (select nid from tb1 where nid < 当前页最小值 order by nid desc limit 每页数据 *【页码-当前页】) A order by A.nid asc limit 1)  
17     order by 
18         nid desc 
19     limit 10;
20 
21 
22 
23     select 
24         * 
25     from 
26         tb1 
27     where 
28         nid < (select nid from (select nid from tb1 where nid < 970  order by nid desc limit 40) A order by A.nid asc limit 1)  
29     order by 
30         nid desc 
31     limit 10;
32 
33 
34 上一页:
35 
36     select 
37         * 
38     from 
39         tb1 
40     where 
41         nid < (select nid from (select nid from tb1 where nid > 当前页最大值 order by nid asc limit 每页数据 *【当前页-页码】) A order by A.nid asc limit 1)  
42     order by 
43         nid desc 
44     limit 10;
45 
46 
47     select 
48         * 
49     from 
50         tb1 
51     where 
52         nid < (select nid from (select nid from tb1 where nid > 980 order by nid asc limit 20) A order by A.nid desc limit 1)  
53     order by 
54         nid desc 
55     limit 10;

以上是关于MySQL实现分页-基于limit方式的主要内容,如果未能解决你的问题,请参考以下文章

MySQL的分页你还在使劲的limit?

sql server实现Mysql中的limit分页功能

MySQL提升效率之limit

mysql limit 分页

mysql limit 分页

MyBatis物理分页的代码实现