记一次慢查询的SQL优化

测试表结构
MariaDB [shoppings]> desc login_userinfo;
+------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+----------------+
| num | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(16) | NO | UNI | NULL | |
| password | varchar(40) | NO | | NULL | |
| nickname | varchar(16) | NO | | NULL | |
| sex | varchar(10) | NO | | NULL | |
| settime | datetime(6) | NO | | NULL | |
| addr | varchar(32) | NO | | NULL | |
| email | varchar(32) | NO | | NULL | |
| phone | varchar(11) | NO | | NULL | |
| receiver | varchar(64) | NO | | NULL | |
| code | varchar(6) | NO | | NULL | |
| comment_id | int(11) | YES | MUL | NULL | |
+------------+-------------+------+-----+---------+----------------+
12 rows in set (0.003 sec)
表中数据量
MariaDB [shoppings]> select count(*) from login_userinfo;
+----------+
| count(*) |
+----------+
| 11809884 |
+----------+
1 row in set (2.503 sec)

分页

MariaDB [shoppings]> select u.num, u.name, u.nickname, u.settime, u.addr,c.content from login_userinfo as u inner join login_comment as c on u.comment_id=c.id limit 10000000, 10;
+----------+--------------+--------------+----------------------------+------+---------+
| num | name | nickname | settime | addr | content |
+----------+--------------+--------------+----------------------------+------+---------+
| 20010049 | test20014998 | test20014998 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
| 20010050 | test20014999 | test20014999 | 2021-02-20 00:00:00.000000 | 北京 | 不太行 |
| 20010051 | test20015000 | test20015000 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010052 | test20015001 | test20015001 | 2021-02-20 00:00:00.000000 | 北京 | 不太行 |
| 20010053 | test20015002 | test20015002 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010054 | test20015003 | test20015003 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
| 20010055 | test20015004 | test20015004 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010056 | test20015005 | test20015005 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010057 | test20015006 | test20015006 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
| 20010058 | test20015007 | test20015007 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
+----------+--------------+--------------+----------------------------+------+---------+
10 rows in set (1 min 6.340 sec)

这次查询需要1分6秒,很明显当数据量过大时 查询效率会直线下降 ,使用者毫无体验(#-_-)

MariaDB [shoppings]> explain select u.num, u.name, u.nickname, u.settime, u.addr,c.content from login_userinfo as u inner join login_comment as c on u.comment_id=c.id limit 10000000, 10;

查看执行计划会看到它可能进行了全表扫描

MariaDB [shoppings]> explain select u.num, u.name, u.nickname, u.settime, u.addr,c.content from login_userinfo as u inner join login_comment as c on u.comment_id=c.id limit 10000000, 10;
+------+-------------+-------+-------+--------------------------------------------------------+--------------------------------------------------------+---------+----------------+--------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+------+-------------+-------+-------+--------------------------------------------------------+--------------------------------------------------------+---------+----------------+--------+-------------+
| 1 | SIMPLE | c | index | PRIMARY | content | 380 | NULL | 17 | Using index |
| 1 | SIMPLE | u | ref | Login_userinfo_comment_id_3d2eced3_fk_Login_comment_id | Login_userinfo_comment_id_3d2eced3_fk_Login_comment_id | 5 | shoppings.c.id | 681715 | |
+------+-------------+-------+-------+--------------------------------------------------------+--------------------------------------------------------+---------+----------------+--------+-------------+
2 rows in set (0.001 sec)

优化

查询主键num值

MariaDB [shoppings]> select num from login_userinfo limit 10000000,1;
+----------+
| num |
+----------+
| 20010043 |
+----------+
1 row in set (3.259 sec)
MariaDB [shoppings]> explain select num from login_userinfo limit 10000000,1;
+------+-------------+----------------+-------+---------------+--------------------------------------------------------+---------+------+----------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+------+-------------+----------------+-------+---------------+--------------------------------------------------------+---------+------+----------+-------------+
| 1 | SIMPLE | login_userinfo | index | NULL | Login_userinfo_comment_id_3d2eced3_fk_Login_comment_id | 5 | NULL | 10907448 | Using index |
+------+-------------+----------------+-------+---------------+--------------------------------------------------------+---------+------+----------+-------------+
1 row in set (0.000 sec)

虽然我们也进行了全表扫描,但是我们用的是主键索引,所以效率会更高。

通过主键num值,查询

MariaDB [shoppings]> select u.num, u.name, u.nickname, u.settime, u.addr,c.content from login_userinfo as u inner join login_comment as c on u.comment_id=c.id where u.num>20010043 limit 10;
+----------+--------------+--------------+----------------------------+------+---------+
| num | name | nickname | settime | addr | content |
+----------+--------------+--------------+----------------------------+------+---------+
| 20010045 | test20014994 | test20014994 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
| 20010046 | test20014995 | test20014995 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010047 | test20014996 | test20014996 | 2021-02-20 00:00:00.000000 | 北京 | 不太行 |
| 20010048 | test20014997 | test20014997 | 2021-02-20 00:00:00.000000 | 上海 | 不太行 |
| 20010049 | test20014998 | test20014998 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
| 20010050 | test20014999 | test20014999 | 2021-02-20 00:00:00.000000 | 北京 | 不太行 |
| 20010051 | test20015000 | test20015000 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010052 | test20015001 | test20015001 | 2021-02-20 00:00:00.000000 | 北京 | 不太行 |
| 20010053 | test20015002 | test20015002 | 2021-02-20 00:00:00.000000 | 广州 | 不太行 |
| 20010054 | test20015003 | test20015003 | 2021-02-20 00:00:00.000000 | 深圳 | 不太行 |
+----------+--------------+--------------+----------------------------+------+---------+
10 rows in set (0.020 sec)
MariaDB [shoppings]> explain select u.num, u.name, u.nickname, u.settime, u.addr,c.content from login_userinfo as u inner join login_comment as c on u.comment_id=c.id where u.num>20010044 limit 10;
+------+-------------+-------+--------+----------------------------------------------------------------+---------+---------+------------------------+---------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+------+-------------+-------+--------+----------------------------------------------------------------+---------+---------+------------------------+---------+-------------+
| 1 | SIMPLE | u | range | PRIMARY,Login_userinfo_comment_id_3d2eced3_fk_Login_comment_id | PRIMARY | 4 | NULL | 3638072 | Using where |
| 1 | SIMPLE | c | eq_ref | PRIMARY | PRIMARY | 4 | shoppings.u.comment_id | 1 | |
+------+-------------+-------+--------+----------------------------------------------------------------+---------+---------+------------------------+---------+-------------+

我们先拿到主键num的值 ,再通过num 进行查询。通过这两次查询 时间不到4秒。效率大大提升。

慢查询SQL优化的更多相关文章

  1. 查询SQL优化

    SQL优化的一般步骤 通过show status命令了解各种SQL的执行频率定位执行效率较低的SQL语句,重点select通过explain分析低效率的SQL确定问题并采取相应的优化措施 优化措施 s ...

  2. 树形查询SQL优化一例

    上周五一哥们发了条SQL,让我看看,代码如下: SELECT COUNT(1) FROM (select m.sheet_id from cpm_main_sheet_history m, cpm_s ...

  3. 1 min 数据查询 SQL 优化

    问题 前几天线上数据库 IOPS 飙升,一直居高不下,最近并没有升级.遂查看数据库正在执行的 SQL 语句,发现有个查询离线设备的语句极其缓慢. 探寻原因 SELECT o.* FROM ( SELE ...

  4. oracle查询SQL优化相当重要

    如果表中的时间字段是索引,那么时间字段不要使用函数,函数会使索引失效. 例如: select * from mytable where trunc(createtime)=trunc(sysdate) ...

  5. Mysql 分页查询sql优化

    先查下数据表的总条数: SELECT COUNT(id) FROM ts_translation_send_address 执行分页界SQL 查看使用时间2.210s SELECT * FROM ts ...

  6. mysql联合查询sql优化

    我们在使用mysql数据库时,经常会使用到mysql的联合查询,联合查询分为内连接和外连接,内连接查询结果是联合的表都存在匹配才会有结果,外连接则根据驱动表是否存在匹配来生成结果集. 这里使用mysq ...

  7. 数据库的规范和SQL优化技巧总结

    现总结工作与学习中关于数据库的规范设计与优化技巧 1.规范背景与目的 MySQL数据库与 Oracle. SQL Server 等数据库相比,有其内核上的优势与劣势.我们在使用MySQL数据库的时候需 ...

  8. 【MySQL】SQL优化系列之 in与range 查询

    首先我们来说下in()这种方式的查询 在<高性能MySQL>里面提及用in这种方式可以有效的替代一定的range查询,提升查询效率,因为在一条索引里面,range字段后面的部分是不生效的. ...

  9. SQL 查询性能优化----解决书签查找

    先来看看什么是书签查找: 当优化器所选择的非聚簇索引只包含查询请求的一部分字段时,就需要一个查找(lookup)来检索其他字段来满足请求.对一个有聚簇索引的表来说是一个键查找(key lookup), ...

  10. 提高SQL查询效率(SQL优化)

    要提高SQL查询效率where语句条件的先后次序应如何写 http://blog.csdn.net/sforiz/article/details/5345359   我们要做到不但会写SQL,还要做到 ...

随机推荐

  1. FreeMarker 去除循环末尾的符号

    在使用 FreeMarker 模板引擎来生成文件时,经常会使用到 list 标签用于循环生成. 有时会遇到需要处理末尾符号的情况,比如 Json 文件,循环生成的标签中末尾是不需要 , 的,例如: & ...

  2. java switch 自定义表格的渲染和编辑示例

    目录 正常使用表格 自定义表格样式 正常使用表格 很简单,使用一次就知道了,不过多介绍. // 创建 JTable 实例,使用默认的模型 JTable table = new JTable(); // ...

  3. MogDB/openGauss 坏块测试-对启动的影响-测试笔记1

    MogDB/openGauss 坏块测试-对启动的影响-测试笔记 1 在 UPDATE 操作提交后,脏块落盘前 kill 掉 mogdb 数据库,然后对 UPDATE 修改的坏进行以下破坏操作,仍然能 ...

  4. openEuler20.03操作系统上安装部署MogDB2.1.1

    openEuler20.03 操作系统上安装部署 MogDB2.1.1 本文出处:https://www.modb.pro/db/378319 openEuler 操作系统上安装 mogdb: 下载 ...

  5. Prometheus之grafana(No data to show)

    一.问题现象 1.grafana添加数据源后获取不到监控数据(No data to show) 2.prometheus以下报错 二.问题原因 服务器与浏览器时间不同步的原因,服务器端配置NTP服务和 ...

  6. 重新点亮linux 命令树————网络配置的查看[十一三]

    前言 简单整理一下网络配置. 正文 通过ifconfig 查看. 这个就是ip地址. 网卡mac地址. 还有一块信息非常重要: 这个io开头的信息,这里面就是我们127.0.0.1的信息. 那么就来演 ...

  7. Worker 进行多线程任务开发

    概念介绍 在 OpenHarmony 中,UI 线程负责处理 UI 事件和用户交互,而 Worker 线程用于处理耗时操作,以提高应用程序的响应速度和用户体验. Worker 线程是与主线程并行的独立 ...

  8. Cube 技术解读 | 支付宝新一代动态化技术架构与选型综述

    ​简介: 支付宝客户端的动态化技术经历三个阶段:现阶段也就是第三阶段是实体组件+部分光栅化的hybrid模式,Cube 就是该模式下的产物. ​ 如标题所述,笔者将持续更新<Cube 技术解读& ...

  9. [Mobi] frida Hook 略知一二: frida-CLI, frida-server

    Frida 是一款基于 python + javascript 的 hook 框架,主流平台都支持,由于是基于脚本的交互,因此相比 xposed 和 substrace cydia 更加便捷. 使用时 ...

  10. STM32F10x 串口使用DMA

    一.DMA简介 DMA(Direct Memory Access,直接存储器访问) 是所有现代电脑的重要特色,它允许不同速度的硬件装置来沟通,而不需要依赖于 CPU 的大量中断负载.否则,CPU 需要 ...