Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 645|回复: 0

最快速的办法解决MySQL数据量增大之后翻页慢问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-9-3 16:14:09 | 显示全部楼层 |阅读模式

    MySQL最易碰到的性能问题就是数据量逐步增大之后的翻页速度变慢的额问题,而且越往后翻页速度越慢,如果用最快速的办法解决,以下就是解决办法,简单方便。

    1、问题现状

          现有MySQL数据表 event_data ,数据量 36.7万,如下:

    mysql> select count(1) from event_data;
    +----------+
    | count(1) |
    +----------+
    |   367961 |
    +----------+
    1 row in set (0.05 sec)

         使用SQL-Limit分页查询,需要花费时间382秒,如下:

       SELECT a.*
         FROM event_data a
        WHERE a.receive_time >= '2018-03-28 00:00:00'
          AND a.receive_time <= '2018-03-28 23:59:59'
     ORDER BY a.receive_time DESC
        LIMIT 56280,15;

         其中 receive_time  字段已建立索引,event_data 表的主键字段为 pk_id。

    2、问题分析

          但是如果把上面的SQL稍微变动一下,就会发现查询速度有质的飞跃,如下:

    mysql>    SELECT a.pk_id
        ->      FROM event_data a
        ->     WHERE a.receive_time >= '2018-03-28 00:00:00'
        ->       AND a.receive_time <= '2018-03-28 23:59:59'
        ->  ORDER BY a.receive_time DESC
        ->     LIMIT 56280,15;
    +----------------------------------+
    | pk_id                            |
    +----------------------------------+
    | ce7d990f39a4411c88ebb3240497e6f3 |
    | bd47b1c380c946c39b3ec172a262823f |
    | c1820a5633714a5e9a0b0c2abb092579 |
    | d58456cbe16d4cc4a20645c1126fb9b7 |
    | a1d786640ea048a7bd10bd9f12868d6d |
    | f590aa4f26034dd9af2f4ba0d4f7430c |
    | af3e81eb43b84467bd3e2c7ad31d6aff |
    | 3ee331dce2064a788515986a0a97ac2b |
    | 46f462dc4209499f90dad2dc4076e4ca |
    | 8ebb7ff55bc443e4854e583f6dc37ff7 |
    | 883fd68d93dc49eab5b35ebf9ab8f8ee |
    | 932c264d6dd140f3ac4f07f3410ce147 |
    | 19b6426cdd664fe2983166e0cca93c53 |
    | 3a0bfa4e000e4b69bba1a6bed6545973 |
    | 5640a162380346f19d57a61c1dc0dd42 |
    +----------------------------------+
    15 rows in set (0.03 sec)

      查询结果返回只需要30毫秒,虽然SQL变动很小,只是将查询结果 由 a.* 改为了 a.pk_id,但是速度的提升是巨大的。

      原因分析:两条SQL where 条件语句都是使用了索引的,这里没有问题,但是查询结果不同,利用了索引查询的语句中如果只包含了索引列(覆盖索引),那么这种情况会查询很快,这里就是这种情况。

    利用覆盖索引,将查询语句需要扫描表的行数降低到最少,即可降低查询时间。

    3、问题解决

        按照上面的分析,我们使用表连接的情况实现SQL优化,如下:

    select a.* FROM (
                SELECT pk_id 
                  FROM event_data c 
                 WHERE c.receive_time >= '2018-03-28 00:00:00' 
                   AND c.receive_time <= '2018-03-28 23:59:59' 
                        ORDER BY c.receive_time DESC 
                 LIMIT 56280,15
                    ) b 
          left join event_data a 
                 on a.pk_id=b.pk_id

    执行时间为0.048秒,达到优化目标。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-21 15:35 , Processed in 0.077833 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表