• 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;
  • 相关阅读:
    版本管理
    图解电路
    Java语言基础
    电工学入门
    11个例子教会你看电路图
    如何提高STM32的学习效率
    开发板入门
    Altium Designer
    电子设计从零开始
    推荐书籍
  • 原文地址:https://www.cnblogs.com/june-L/p/12150508.html
Copyright © 2020-2023  润新知