zoukankan      html  css  js  c++  java
  • Mysql中的分页处理

    先来说一下Mysql中limit的语法:

    --语法:
    SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset
    --举例:
    
    select * from table limit 5; --返回前5行
    
    select * from table limit 0,5; --同上,返回前5行
    
    select * from table limit 5,10; --返回6-15行

    Mysql中分页主要利用limit能够根据偏移量返回结果的特性:

    select ... from ... where ... order by ... desc limit pagesize * (page - 1), pagesize;
    
    --举例:取t_u_coach表中按coachId降序排列后第5页的教练列表,其中每页10个教练
    select * from t_u_coach where id > 10000 order by coachId desc limit 40, 10;

    在中小数据量的情况下,唯一需要注意的是coachId和id最好已经建立了聚合索引。

    但是当数据量很大的时候,limit m,n 的性能随着m的增加而急剧下降。比如:

    --举例:偏移值过大的时候性能下降
    select * from t_u_coach where id > 10000 order by coachId desc limit 40000, 10;

    此时,通常有两种方法来进行优化:

    一,使用子查询的方式来进行分页

    select * from t_u_coach where coachId >= (select coachId from t_u_coach where id > 10000 order by coachId desc  limit 40000, 1) limit 10;

    二,使用join的方式来进行分页

    select * from t_u_coach as t1 join (select coachId from t_u_coach where id > 10000 order by coachId desc limit 40000, 1) as t2 where t1.coachId >= t2.coachId order by t1.coachId desc limit 10;

    使用子查询来进行分页优化的时候,主要是因为能在子查询中使用索引。

    别让生活压力挤走快乐~
  • 相关阅读:
    指定时间的月初和月末一天的写法
    EF写distinct
    服务的调试和安装
    EF写INNER JOIN 链接
    BZOJ 1825: [JSOI2010]蔬菜庆典
    P4171 [JSOI2010]满汉全席
    Educational Codeforces Round 71 (Rated for Div. 2) Solution
    P4292 [WC2010]重建计划
    P3724 [AH2017/HNOI2017]大佬
    P5504 [JSOI2011]柠檬
  • 原文地址:https://www.cnblogs.com/cookiehu/p/4892476.html
Copyright © 2011-2022 走看看