慢查询SQL优化
记一次慢查询的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优化的更多相关文章
- 查询SQL优化
SQL优化的一般步骤 通过show status命令了解各种SQL的执行频率定位执行效率较低的SQL语句,重点select通过explain分析低效率的SQL确定问题并采取相应的优化措施 优化措施 s ...
- 树形查询SQL优化一例
上周五一哥们发了条SQL,让我看看,代码如下: SELECT COUNT(1) FROM (select m.sheet_id from cpm_main_sheet_history m, cpm_s ...
- 1 min 数据查询 SQL 优化
问题 前几天线上数据库 IOPS 飙升,一直居高不下,最近并没有升级.遂查看数据库正在执行的 SQL 语句,发现有个查询离线设备的语句极其缓慢. 探寻原因 SELECT o.* FROM ( SELE ...
- oracle查询SQL优化相当重要
如果表中的时间字段是索引,那么时间字段不要使用函数,函数会使索引失效. 例如: select * from mytable where trunc(createtime)=trunc(sysdate) ...
- Mysql 分页查询sql优化
先查下数据表的总条数: SELECT COUNT(id) FROM ts_translation_send_address 执行分页界SQL 查看使用时间2.210s SELECT * FROM ts ...
- mysql联合查询sql优化
我们在使用mysql数据库时,经常会使用到mysql的联合查询,联合查询分为内连接和外连接,内连接查询结果是联合的表都存在匹配才会有结果,外连接则根据驱动表是否存在匹配来生成结果集. 这里使用mysq ...
- 数据库的规范和SQL优化技巧总结
现总结工作与学习中关于数据库的规范设计与优化技巧 1.规范背景与目的 MySQL数据库与 Oracle. SQL Server 等数据库相比,有其内核上的优势与劣势.我们在使用MySQL数据库的时候需 ...
- 【MySQL】SQL优化系列之 in与range 查询
首先我们来说下in()这种方式的查询 在<高性能MySQL>里面提及用in这种方式可以有效的替代一定的range查询,提升查询效率,因为在一条索引里面,range字段后面的部分是不生效的. ...
- SQL 查询性能优化----解决书签查找
先来看看什么是书签查找: 当优化器所选择的非聚簇索引只包含查询请求的一部分字段时,就需要一个查找(lookup)来检索其他字段来满足请求.对一个有聚簇索引的表来说是一个键查找(key lookup), ...
- 提高SQL查询效率(SQL优化)
要提高SQL查询效率where语句条件的先后次序应如何写 http://blog.csdn.net/sforiz/article/details/5345359 我们要做到不但会写SQL,还要做到 ...
随机推荐
- 可视化学习:使用WebGL绘制圆形,实现色盘
前言 在Canvas2D中实现圆形的绘制比较简单,只要调用arc指令就能在Canvas画布上绘制出一个圆形,类似的,在SVG中我们也只需要一个<circle>标签就能在页面上绘制一个圆形. ...
- .NET 9 预览版 3 发布
我们很高兴地宣布发布 .NET 9 预览版 3,其中包含 .NET 库.运行时和 SDK 的新功能和改进.此预览版带来了旨在提高性能.提高开发人员工作效率以及向 .NET 生态系统引入新功能的增强功能 ...
- android虚拟机硬件加速问题
前言 创建的android 虚拟机的如果我们选择x86,那么会出现需要硬件加速. 步骤 那么打开虚拟功能后可以进行安装,SDK Manager-> Extras->Intel Hardwa ...
- mysql 重新整理——索引优化explain字段介绍一 [九]
前言 在七种介绍了explain这东西,那么具体来看下它是如何来运行的吧. 正文 id 来看一条语句:EXPLAIN select * from departments,dept_emp,employ ...
- Go 单元测试基本介绍
目录 一.单元测试基本介绍 1.1 什么是单元测试? 1.2 如何写好单元测试 1.3 单元测试的优点 1.4 单元测试的设计原则 二.Go语言测试 2.1 Go单元测试概要 2.2 Go单元测试基本 ...
- 介绍一个气缸控制的FB程序块
关键词: 气缸,双控.单控.电磁阀.感应器.初始位置(简称"始位").末端位置(简称"端位").屏蔽功能.延时功能.报警功能 正文: 1.为什么要做气缸FB功能 ...
- vue中执行异步函数async和await的用法
在开发中,可能会遇到两个或多个函数异步执行的情况,对于Vue中函数的异步函数执行做了一个小总结,如下: 异步执行使用async和await完成 created() { this.init() }, m ...
- HBuilderX 连接网易mumu手机模拟器进行App开发
1.下载安装手机模拟器 常见的安卓手机模拟器: 手机模拟器名称 对应端口号 夜神模拟器 62001 天天模拟器 6555 海马玩模拟器 26944 逍遥模拟器 21503 网易mumu模拟器 7555 ...
- JavaScript中数值小知识
1. 数值10.0 这种类似的会被去掉数值后的0 之所以这样是因为,整数的存储空间占用比浮点数小,当一个数值不是真浮点数(即10.0这种格式),会被转换为整数10,如果业务中有一些需求需要进行数值位数 ...
- 国内唯一连续入选Gartner,Quick BI是如何做到的?
简介:阿里云Quick BI凭借灵活的公共云部署,私有化独立部署能力.无缝对接各类云上数据库和自建数据库.可视化搭建分析.高效数据处理能力与强大数据计算能力,使得在2022年持续入选Gartner ...