sql 性能优化基于explain调优

简介: sql 性能优化基于explain调优


Explain分析?

关于Explain具体可以干什么,有哪些优缺点,本博主的文章有写到,这是链接地址: 点击这里查看. 下面来说下Explain在项目实战中,如何去进行优化。

问题描述

简单描述一下问题:今天项目经理安排了一个艰巨的任务,xx去优化一下xx那个查询语句,前端列表显示太慢了,影响客户体验,抱着这个问题,我先去查询了一下后端接口,确定了哪个接口下,便找到了SQL语句贴到了下面,在我还没说怎么优化前,大家可以先去看一下

仔细分析一下这段SQL语句先去进行左连接left join,再去进行内连接inner join,经过反复执行,最终确定了问题,出在了inner JOIN sg_device_relevance b ON c.id = b.member_id 注释或者使用left join查询后,问题一:查询出来的数据不对,问题二:查询速度反而比之前更慢了

解决方案

SELECT c.id,
        c.NAME AS 'name',
        c.sex,
        c.phone,
        c.three_tag,
        c.dept_id,
        c.region,
        c.compliance,
        c.sys_org_code,
        a.measuring_time
        FROM sg_member c
        LEFT JOIN
        sg_blutdruck_record a
        ON c.id = a.member_id AND a.measuring_time BETWEEN DATE_SUB(NOW(), INTERVAL 7 DAY) AND NOW()
        inner JOIN
        sg_device_relevance b
        ON c.id = b.member_id
        WHERE 1 = 1
        and c.sys_org_code = 'A02A01'
         AND a.id IS NULL
        GROUP BY c.id

根据上面的SQL,看下我没加索引前的执行结果,查询时间时3秒多,在select前面加上EXPLAIN关键字,分析结果如下,type:代表扫描类型,类型为ALL代表全局扫描,possible_keys:代表应该用到哪些索引,key:代表实际用到的索引, 有些人就开始疑惑了,为什么实际没有用到索引呢,原因是PRIMARY,unique验证唯一值索引,再此处用不上

我这个地方分割一下,继续往下说,一定要讲明白,非常重要这块,不仅在项目中可以用到,面试也常问,不明白的可以私信.

rows:代表检索的数据行数,Extra:代表检索结果,Using index就是用到了索引,很明显这个地方结果返回没有用上,另外type检索类型也是全局检索,type具体有几种类型可以去博文中查询,在本文章上方我贴上文章地址了,这些我都解释完了,下面看下我优化后的查询结果

优化后

-- 向a表添加索引
 create index device_relevancekey on sg_device_relevance(member_id)
 -- 向B表添加索引
 create index blutdruck_record on sg_blutdruck_record(member_id,measuring_time)

看下这时的type:ref,明显这次没有用全局扫描,C表我没加索引的原因呢是:在此处查询中为主表,看下a和b表,实际用到的索引和应该用到的索引一直,说明用到了索引,Extra:a和b表的扫描结果为Using index,说明索引生效了,查询时间为0.21秒,比刚才快了3秒多注意:这次优化我没有去改SQL,而是加了索引,其实改SQL也可以,但是我这样做呢,其他查询也会同样速度比之前快了很多

本次分享就到这里啦,如果有不明白的地方可以私信本博主,后期会分享更多在项目中遇到的实战技术及问题

目录
相关文章
|
2月前
|
存储 SQL 关系型数据库
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
MySQL调优主要分为三个步骤:监控报警、排查慢SQL、MySQL调优。 排查慢SQL:开启慢查询日志 、找出最慢的几条SQL、分析查询计划 。 MySQL调优: 基础优化:缓存优化、硬件优化、参数优化、定期清理垃圾、使用合适的存储引擎、读写分离、分库分表; 表设计优化:数据类型优化、冷热数据分表等。 索引优化:考虑索引失效的11个场景、遵循索引设计原则、连接查询优化、排序优化、深分页查询优化、覆盖索引、索引下推、用普通索引等。 SQL优化。
543 15
【MySQL调优】如何进行MySQL调优?从参数、数据建模、索引、SQL语句等方向,三万字详细解读MySQL的性能优化方案(2024版)
|
1月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
1月前
|
SQL 机器学习/深度学习 关系型数据库
最完整的Explain总结,SQL优化不再困难!
最完整的Explain总结,SQL优化不再困难!
|
1月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
1月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
53 1
|
2月前
|
SQL 分布式计算 数据库
SQL调优总结
数据库表的规范化和反规范化设计,设计合适的字段数据类型……
44 8
|
3月前
|
Java XML Maven
跨越时代的飞跃:Struts 2 升级秘籍——从旧版本无缝迁移到最新版,焕发应用新生!
【8月更文挑战第31天】随着软件技术的发展,Struts 2 框架也在不断更新。本文通过具体案例指导开发者如何从旧版平滑升级到 Struts 2.6.x。首先更新 `pom.xml` 中的依赖版本,并执行 `mvn clean install`。接着检查 `struts.xml` 配置,确保符合新版本要求,调整包扫描器等设置。审查 Action 类及其注解,检查配置文件中的弃用项及插件。更新自定义拦截器实现,并验证日志配置。最后,通过一系列测试确保升级后的系统正常运行。通过这些步骤,可以顺利完成 Struts 2 的版本升级,提升应用的安全性和性能。
211 0
|
3月前
|
Java 开发者 前端开发
Struts 2、Spring MVC、Play Framework 上演巅峰之战,Web 开发的未来何去何从?
【8月更文挑战第31天】在Web应用开发中,Struts 2框架因强大功能和灵活配置备受青睐,但开发者常遇配置错误、类型转换失败、标签属性设置不当及异常处理等问题。本文通过实例解析常见难题与解决方案,如配置文件中遗漏`result`元素致页面跳转失败、日期格式不匹配需自定义转换器、`<s:checkbox>`标签缺少`label`属性致显示不全及Action中未捕获异常影响用户体验等,助您有效应对挑战。
89 0
|
3月前
|
SQL 存储 数据库
|
3月前
|
SQL 数据处理 数据库
SQL正则表达式应用:文本数据处理的强大工具——深入探讨数据验证、模式搜索、字符替换等核心功能及性能优化和兼容性问题
【8月更文挑战第31天】SQL正则表达式是数据库管理和应用开发中处理文本数据的强大工具,支持数据验证、模式搜索和字符替换等功能。本文通过问答形式介绍了其基本概念、使用方法及注意事项,帮助读者掌握这一重要技能,提升文本数据处理效率。尽管功能强大,但在不同数据库系统中可能存在兼容性问题,需谨慎使用以优化性能。
56 0