MySQL SQL优化技巧与原理

前言

随着业务数据量的不断增加,MySQL查询语句的执行效率对程序的运行效率影响逐渐增大。因此,进行SQL优化变得至关重要。本文将结合SQL的执行语句顺序和各种SQL场景,介绍一些常见的MySQL SQL优化技巧及其背后的原理。

一、MySQL SQL执行语句顺序

MySQL SQL的执行顺序通常分为以下步骤:

  1. FROM子句:加载表,计算笛卡尔积,生成虚拟表VT1。
  2. ON子句:筛选关联表符合ON表达式的数据,生成虚拟表VT2。
  3. JOIN子句:继续连接其他表,更新虚拟表VT3。
  4. WHERE子句:筛选掉不符合条件的数据,生成虚拟表VT4。
  5. GROUP BY子句:分组,生成虚拟表VT5。
  6. HAVING子句:筛选分组后的数据,生成虚拟表VT6。
  7. SELECT子句:选择列,生成虚拟表VT7。
  8. DISTINCT子句:去重,生成虚拟表VT8(若执行了GROUP BY,则无需此步骤)。
  9. ORDER BY子句:排序,生成游标(不返回虚拟表)。
  10. LIMIT子句:限制返回结果集大小,将结果返回给客户端。
二、MySQL SQL优化技巧
  1. **避免使用SELECT ***

    在实际业务场景中,可能真正需要使用的只有其中一两列。使用SELECT *会浪费数据库资源,如内存和CPU,并且不会走覆盖索引,导致大量回表操作,降低查询性能。因此,应尽量明确选择需要的列。

    SELECT column1, column2 FROM table WHERE condition;
    
  2. 使用LIMIT控制结果集大小

    在查询中尽量使用LIMIT限制返回的结果集大小,减少数据传输时间和数据库资源消耗。

    SELECT column1, column2 FROM table WHERE condition LIMIT 10;
    
  3. 优化子查询

    尽量避免使用子查询,特别是在子查询返回大量数据时。可以使用JOIN来代替子查询,提高效率。

    -- 不推荐
    SELECT * FROM customers WHERE customer_id IN (SELECT customer_id FROM orders);-- 推荐
    SELECT c.customer_name FROM customers c JOIN orders o ON c.customer_id = o.customer_id;
    
  4. 使用EXISTS代替IN

    当子查询结果集非常大时,EXISTS通常比IN性能更好。EXISTS会逐条检查是否存在满足条件的记录,一旦找到匹配的数据则停止检查。

    -- 不推荐
    SELECT customer_name FROM customers WHERE customer_id IN (SELECT customer_id FROM orders);-- 推荐
    SELECT customer_name FROM customers c WHERE EXISTS (SELECT 1 FROM orders o WHERE o.customer_id = c.customer_id);
    
  5. 小表驱动大表

    在关联查询中,尽量使用小表的数据集驱动大表的数据集。例如,在JOIN操作中,将小表放在前面,可以减少查询的时间复杂度。

    SELECT * FROM order WHERE user_id IN (SELECT id FROM user WHERE status = 1);
    
  6. 批量操作

    在进行数据插入、更新等操作时,尽量使用批量操作,减少数据库请求次数,提高性能。

    INSERT INTO table (column1, column2) VALUES (value1, value2), (value3, value4), ...;
    
  7. 合理使用索引

    合理的索引设计可以大大提高查询效率。但需要注意的是,过多或不必要的索引也会对性能产生负面影响。应根据实际情况选择合适的索引类型,如B树索引、哈希索引等。

  8. 优化数据库结构

    将数据表进行垂直分割,将数据量大的字段分离出来,减少不必要的重复数据。通过合理的表结构设计,提高查询效率。

  9. 使用缓存

    使用Memcached等缓存工具,减少数据库的访问次数,提高性能。特别是在高并发场景下,缓存可以显著减轻数据库的压力。

  10. 调整数据库参数

    根据应用的需求,适当调整MySQL的参数配置,如max_connectionsinnodb_buffer_pool_size等,以提高系统性能。

  11. 避免长事务和死锁

    长事务和死锁会占用大量的资源,降低系统的性能。因此,应避免长事务和死锁的发生,确保系统的稳定性和高效性。

三、优化方案背后的原理
  1. 查询缓存

    MySQL的查询缓存系统可以缓存查询结果,提高查询效率。但需要注意的是,查询缓存对系统的额外消耗也不容忽视。当缓存带来的资源节约大于其本身消耗的资源时,才会给系统带来性能提升。因此,在使用查询缓存时,需要合理控制缓存空间大小,并根据实际情况决定是否开启查询缓存。

  2. 解析与优化

    MySQL的解析器负责将SQL语句解析成解析树,并进行语法检查。优化器则根据解析树生成最优的执行计划。执行计划的选择直接影响查询性能。MySQL使用基于成本的优化器,尝试预测一个查询使用某种执行计划时的成本,并选择其中成本最小的一个。因此,合理的索引设计和表结构设计可以优化执行计划,提高查询效率。

  3. 存储引擎

    MySQL支持多种存储引擎,如MyISAM、InnoDB等。不同的存储引擎有不同的特点和性能表现。在选择存储引擎时,需要根据实际应用场景选择合适的存储引擎,并合理配置存储引擎的参数,以提高系统性能。

  4. 系统文件层

    系统文件层负责将数据库的数据和日志存储在文件系统之上,并完成与存储引擎的交互。通过合理的文件系统和磁盘配置,可以提高数据的读写速度,进而提高查询性能。

四、总结

MySQL的SQL优化是一个复杂而系统的过程,需要综合考虑多个方面。通过避免使用SELECT *、使用LIMIT控制结果集大小、优化子查询、使用EXISTS代替IN、小表驱动大表、批量操作、合理使用索引、优化数据库结构、使用缓存、调整数据库参数以及避免长事务和死锁等技巧,可以有效提高MySQL的查询效率。同时,了解MySQL的工作原理和SQL执行语句顺序,有助于更好地进行SQL优化。希望本文能对大家有所帮助,提升MySQL的性能和稳定性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67239.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

移动端H5缓存问题

移动端页面缓存问题是指页面的静态资源(如图片、JS 和 CSS 文件)在浏览器中被缓存后,用户在下次访问时可以直接从本地获取缓存数据,而不需要每次都从服务器重新获取,不过这样可能会导致页面不能正确地更新或者加载最新…

长安“战疫”网络安全公益赛的一些随想

起因 今年刚进入大学,开始带校队,为了培养校队新成员,也就一直计划着和当地的一些高校合作交流,但是由于种种原因一直被搁置下来。正巧学校信息中心和四叶草有一个培训项目的合作,学校的网安协会也算是沾了光成为了培…

STM32-keil安装时遇到的一些问题以及解决方案

前言: 本人项目需要使用到STM32,故需配置keil 5,在配置时遇到了以下问题,并找到相应的解决方案,希望能够为遇到相同问题的道友提供一些解决思路 1、提示缺少(missing)version 5编译器 step1:找…

1.1.1 C语言常用的一些函数(持续更新)

总框架见(0. 总框架-CSDN博客) (1)socket (a)分配fd;(b)分配tcp控制块(tcb) int socket(int domain, int type, int protocol);AF_INET IPv4 Internet protocols ip(7)AF_INET6 IP…

CNCF云原生计算基金会

CNCF,全称为云原生计算基金会(Cloud Native Computing Foundation),成立于2015年,是一个隶属于Linux基金会的非营利组织。CNCF旨在促进和支持开源技术的发展,特别是那些支持云原生(cloud native…

【Hive】海量数据存储利器之Hive库原理初探

文章目录 一、背景二、数据仓库2.1 数据仓库概念2.2 数据仓库分层架构2.2.1 数仓分层思想和标准2.2.2 阿里巴巴数仓3层架构2.2.3 ETL和ELT2.2.4 为什么要分层 2.3 数据仓库特征2.3.1 面向主题性2.3.2 集成性2.3.3 非易失性2.3.4 时变性 三、hive库3.1 hive概述3.2 hive架构3.2.…

go-echo学习笔记

go-echo学习笔记,包含了请求与响应,路由,参数解析,模版渲染,登录验证,日志,文件上传与下载,websocket通信。 文章目录 Part1 Get与PostPart2 四种请求Part3 提取参数Part4 解析json…

mqtt详细介绍及集成到springboot

mqtt详细介绍及集成到springboot 1.mqtt发布/订阅消息参数详细介绍2. mqtt客户端连接参数介绍3. docker-compose搭建mqtt服务端4. springboot集成mqtt实现发布订阅5. 测试注意事项 1.mqtt发布/订阅消息参数详细介绍 1.1. qosQoS0 ,Sender 发送的一条消息&#xff0…

【linux命令】ip命令使用

1、设置网口IP 方法1:通过IP设置网口ip 添加静态IP: ip addr add 1.1.1.1/24 dev eth0 删除ip: ip addr del 1.1.1.1/24 dev eth0 方法2:nmtui 配置IP另外方法: nmtui 2、添加路由 添加路由: ip route add 目标网…

基于springboot的租房网站系统

作者:学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等 文末获取“源码数据库万字文档PPT”,支持远程部署调试、运行安装。 项目包含: 完整源码数据库功能演示视频万字文档PPT 项目编码&#xff1…

自动化办公|xlwings简介

xlwings 是一个开源的 Python 库,旨在实现 Python 与 Microsoft Excel 的无缝集成。它允许用户使用 Python 脚本自动化 Excel 操作,读取和写入数据,执行宏,甚至调用 VBA 脚本。这使得数据分析、报告生成和其他与 Excel 相关的任务…

《零基础Go语言算法实战》【题目 4-8】用 Go 语言设计一个遵循最近最少使用(LRU)缓存约束的数据结构

《零基础Go语言算法实战》 【题目 4-8】用 Go 语言设计一个遵循最近最少使用(LRU)缓存约束的数据结构 实现 LRUCache 类。 ● LRUCache(int capacity) :初始化具有正大小容量的 LRU 缓存。 ● int get(int key) :如果 key 存在…

Sonatype Nexus OSS 构建私有docker 仓库

1.Docker Engine 配置 {"builder": {"gc": {"defaultKeepStorage": "20GB","enabled": true}},"dns": ["8.8.8.8","114.114.114.114"],"experimental": false,"features"…

lqb.key按键全套

#include "stc15.h" #define FOSC 11059200L //#define T1MS (65536-FOSC/1000) //1T模式 #define T1MS (65536-FOSC/12/1000) //12T模式typedef unsigned char u8; typedef unsigned int u16; typedef unsigned long u32;#define LY 1 //…

概率函数,累计分布函数

四. 累计分布函数 1. 累计分布函数(CDF, Cumulative Distribution Function) 累计分布函数是用来描述随机变量取值小于或等于某个给定值的概率。它适用于离散型和连续型随机变量,并且能够通过概率质量函数(PMF)或概率…

Docker中编码和时区设置不生效问题排查

一、编码不生效排查 在 docker-compose.yml 中设置了环境变量,但进入 Docker 容器后 LANG 仍然显示为 zh_CN.UTF-8,按照以下步骤进行排查和修复: 1. 确保设置正确 确保你的 docker-compose.yml 文件中环境变量设置没有拼写错误,示…

CSS 样式 margin:0 auto; 详细解读

一、基本语法 margin 属性是用于设置元素的外边距,它可以接受一个、两个、三个或四个值。 margin:0 auto 是一种简洁的写法,其中包含了两个值。 二、值的含义 第一个值 0 表示元素的上下外边距为 0。这意味着该元素的顶部和底部与相邻元素或父元素之间…

【线性代数】行列式的性质

行列式性质定理讲义 一、行列式的基本性质 性质 1:行列互换 对于任意一个 n n n \times n nn 的方阵 A A A,其行列式 ∣ A ∣ |A| ∣A∣ 满足: ∣ A ∣ ∣ A T ∣ |A| |A^T| ∣A∣∣AT∣ 其中, A T A^T AT 是 A A A 的…

python创建pdf水印,希望根据文本长度调整水印字体大小,避免超出页面

为了根据文本长度动态调整水印字体大小,可以先测量文本长度,然后根据页面宽度和高度动态计算合适的字体大小。以下是修改后的代码: from reportlab.pdfgen import canvas from reportlab.lib.pagesizes import letter from reportlab.pdfbas…

Flutter项目适配鸿蒙

Flutter项目适配鸿蒙 前言Flutter项目适配鸿蒙新工程直接支持ohos构建新项目编译运行 适配已有的Flutter项目 前言 目前市面上使用Flutter技术站的app不在少数,对于Flutter的项目,可能更多的是想直接兼容Harmonyos,而不是直接在重新开发一个…