最快速的办法解决MySQL数据量增大之后翻页慢问题
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秒,达到优化目标。
最快速的办法解决MySQL数据量增大之后翻页慢问题的更多相关文章
- MySQL数据库如何解决大数据量存储问题
利用MySQL数据库如何解决大数据量存储问题? 各位高手您们好,我最近接手公司里一个比较棘手的问题,关于如何利用MySQL存储大数据量的问题,主要是数据库中的两张历史数据表,一张模拟量历史数据和一张开 ...
- hadoop job解决大数据量关联时数据倾斜的一种办法
转自:http://www.cnblogs.com/xuxm2007/archive/2011/09/01/2161929.html http://www.geminikwok.com/2011/04 ...
- MYSQL的binary解决mysql数据大小写敏感问题 《转载》
BINARY不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串,可以理解为在字符串比较的时候区分大小写如下:mysql> select binary 'ABCD'='abcd ...
- 对MySQL数据量日益增长产生的一点小想法
最近一直在想一个问题 MySQL数据量日益庞大,目前单表总记录数有 300W+,导致sql语句执行的速度变慢,如果一直这样增长下去,总有一天会爆炸的.怎么办??怎么办?? 第一:想到的必然是 添加索引 ...
- 利用MySQL数据库如何解决大数据量存储问题?
提问:如何设计或优化千万级别的大表?此外无其他信息,个人觉得这个话题有点范,就只好简单说下该如何做,对于一个存储设计,必须考虑业务特点,收集的信息如下:1.数据的容量:1-3年内会大概多少条数据,每条 ...
- MySQL数据库解决大数据量存储问题
转载自:https://www.cnblogs.com/ryanzheng/p/8334915.html 提问:如何设计或优化千万级别的大表?此外无其他信息,个人觉得这个话题有点范,就只好简单说下该如 ...
- 使用POI导出EXCEL工具类并解决导出数据量大的问题
POI导出工具类 工作中常常会遇到一些图表需要导出的功能,在这里自己写了一个工具类方便以后使用(使用POI实现). 项目依赖 <dependency> <groupId>org ...
- MERGE INTO 解决大数据量 10w 更新缓慢的问题
有个同事处理更新数据缓慢的问题,数据量超10w的量,更新速度太慢耗时较长,然后改成了 MERGE INTO 效率显著提高. 使用方法如下 MERGE INTO 表A USING 表B ON 关联条件 ...
- Mysql数据量较大时分页查询优化
据表 collect ( id, title ,info ,vtype) 就这4个字段,其中 title 用定长,info 用text, id 是主键,vtype是int,vtype是索引. 最后co ...
随机推荐
- mysql 的sql_model模式
原文地址:https://blog.csdn.net/baidu_19338587/article/details/59483954 MySQL的sql_mode合理设置 sql_mode是个很容易被 ...
- Numba——python面向数组高性能计算库
python在计算性能上相对c是比较弱鸡的,有了numpy后计算性能短板是补了一些,而Numba库又给python计算性能加了发动机(忽然想到西虹市首富王多鱼的名言:我再加200万,给冰山提提速.), ...
- java的byte[]与String相互转换
String转byte[] byte[] sInput = new byte[0]; try { // 可以指定编码,默认也只UTF-8 sInput = "这是内容".getBy ...
- springboot获取上下文ApplicationContext
在springboot主程序里改成 public static void main(String[] args) { // SpringApplication.run(SpringbootAPP.cl ...
- pipeline的添加顺序和执行顺序
原文链接:https://www.cnblogs.com/ruber/p/10186571.html 本文只想讨论一下pipeline的执行顺序问题,因为这个搞不明白就不知道先添加编码还是解码,是不是 ...
- linux 下用C实现 ATM 自动取款机功能 (进程间通信)
直接先上图: 项目需求: 主要分为两人大模块: 客户端 .进入时的功能开户.销户.登录.解锁 开户:输入姓名.身份证号.设置密码,如果开户成功,则服务器上保存一个账号信号(一个账号存一个文件,文件名建 ...
- FIFO形成3x3矩阵
Verilog生成矩阵一般是使用shift_ip核,但其实用两个FIFO也行.最近刚好学到这种方法,把原理总结一下. 要求 现在有10x5的数据和对应数据有效指示信号,数据为0~49,要用FPGA对其 ...
- gradle中引用本地项目
例如在别的地方有一个 apiProject,里面有 apiModule,你想要引用,而不是复制到现有项目,那么 1.现有项目的settings.gradle下 include ':apiModule' ...
- 「CTS2019」氪金手游
「CTS2019」氪金手游 解题思路 考场上想出了外向树的做法,居然没意识到反向边可以容斥,其实外向树会做的话这个题差不多就做完了. 令 \(dp[u][i]\) 表示单独考虑 \(u\) 节点所在子 ...
- C# vb .net实现对比度调整特效滤镜效果
在.net中,如何简单快捷地实现Photoshop滤镜组中的对比度效果呢?答案是调用SharpImage!专业图像特效滤镜和合成类库.下面开始演示关键代码,您也可以在文末下载全部源码: 设置授权 第一 ...