当前位置:Gxlcms > 数据库问题 > MySQL实现分页-基于limit方式

MySQL实现分页-基于limit方式

时间:2021-07-01 10:21:17 帮助过: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方式

标签:解决   esc   order   size   div   nbsp   利用   排序   table   

人气教程排行