0%

MySQL 执行计划详解:读懂 Explain,优化 SQL 不求人

执行计划(Explain)是 MySQL 优化的 “导航图”,它能模拟优化器执行 SQL 的过程,展示 MySQL 如何解析和执行你的查询。掌握执行计划的分析方法,是写出高效 SQL 的前提。本文将系统拆解执行计划的每个字段,教你如何通过 Explain 定位性能瓶颈。

执行计划的基本使用

通过EXPLAIN关键字可以生成执行计划,语法简单:

1
2
3
4
5
6
-- 基础用法
EXPLAIN SELECT * FROM user WHERE age > 18;

-- 结合索引未使用的原因(配合show warnings)
EXPLAIN SELECT * FROM user WHERE age > 18;
SHOW WARNINGS; -- 显示优化器对SQL的改写和分析

执行后会生成一张包含 12 个字段的表格,每个字段都隐藏着查询的关键信息:

1
2
3
+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+
| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+

执行计划字段详解

1. id:查询执行顺序标识

表示 SELECT 子句或操作表的序号,决定执行顺序

  • id 相同:执行顺序由上至下(按 table 字段顺序)。
    例:多表连接查询中,id 相同表示按表的出现顺序依次访问。
  • id 不同:id 越大优先级越高,先执行(子查询的 id 通常大于外层查询)。
    例:子查询的 id 为 2,外层查询 id 为 1,则先执行子查询。
  • id 混合(有相同也有不同):先执行 id 大的,id 相同的按顺序执行。

2. select_type:查询类型

区分普通查询、子查询、联合查询等,核心类型如下:

阅读全文 »

MySQL 锁机制全解析:类型、原理与实践

MySQL 的锁机制是保障并发场景下数据一致性的核心技术,通过合理的锁定策略协调多个事务对共享资源的访问。不同存储引擎的锁设计差异显著,理解锁的类型、粒度和算法,对优化并发性能、避免死锁至关重要。

锁的基本概念与作用

锁是数据库管理并发访问的规则,核心作用是控制多个事务对共享资源的有序访问,避免因并发操作导致的数据不一致(如脏读、不可重复读、幻读)。

  • 核心流程:事务修改数据前需获取锁 → 持有锁期间独占或共享资源 → 事务提交 / 回滚后释放锁。
  • 设计目标:在 “数据一致性” 和 “并发性能” 之间找到平衡 —— 锁粒度越细,并发越高但开销越大;粒度越粗,开销越小但并发越低。

按锁粒度分类(核心分类方式)

锁的粒度决定了锁定资源的范围,MySQL 支持表锁、行锁和页锁三种粒度,不同存储引擎对锁的支持不同。

表锁(Table Lock):粒度最大,偏读场景

表锁是锁定整张表的机制,实现简单、开销小、无死锁,但并发度低(适合读多写少场景)。

支持的存储引擎:

MyISAM、Memory、CSV 等非事务引擎(InnoDB 也支持表锁,但默认用行锁)。

核心特性:
  • 开销小、加锁快:无需逐行判断,直接锁定整张表。
  • 无死锁:锁定顺序简单,不会出现循环等待。
  • 并发度低:写操作会阻塞所有读写,读操作会阻塞写操作。
锁类型与行为:

表锁分为读锁(共享锁,S 锁)写锁(排他锁,X 锁),规则如下:

阅读全文 »

MySQL 体系结构详解:分层设计与核心组件

MySQL 采用客户机 / 服务器(C/S)架构,通过清晰的分层设计实现高效的数据管理与交互。其体系结构可分为四大层:连接层服务层插件式存储引擎层存储层,每层各司其职,共同完成从客户端请求到数据存储 / 检索的全流程。

整体架构:客户机与服务器的协作

MySQL 的运行依赖两个核心程序:

  • 服务器程序(mysqld):运行在数据库所在服务器,负责监听网络请求、处理 SQL 命令、管理数据存储,并将结果返回给客户端。
  • 客户机程序:如 mysql 命令行工具、图形化工具(Navicat)或编程语言驱动(Python 的 pymysql),负责与服务器建立连接并发送 SQL 请求。

这种架构的优势在于:客户端与服务器可分离部署(跨机器 / 跨网络),服务器集中管理数据,确保一致性与安全性。

四大分层结构及核心组件

总体结构

连接层:客户端与服务器的桥梁

连接层是 MySQL 与外部交互的入口,负责建立和管理客户端与服务器的连接。

核心组件:
阅读全文 »

MySQL 存储引擎深度解析:特性、对比与最佳实践

MySQL 的存储引擎是其区别于其他数据库的核心特性之一,采用表级别的插件式设计,允许为不同表选择最适合的存储引擎以优化性能。

存储引擎的本质与设计理念

存储引擎是 MySQL 中负责数据存储、检索、事务管理、索引实现的底层组件,其设计直接决定了表的:

  • 数据安全性(如事务支持)
  • 并发性能(如锁机制)
  • 存储效率(如压缩、缓存)
  • 功能支持(如外键、全文索引)

由于存储引擎是 “表级” 的,同一数据库中可混合使用不同引擎(例如:订单表用 InnoDB 保证事务,日志表用 MyISAM 优化读取)。

三大核心存储引擎对比与实战

InnoDB(默认引擎,事务优先)

InnoDB 是 MySQL 5.5+ 的默认存储引擎,专为事务安全高并发设计,是绝大多数业务的首选。

核心特性:
阅读全文 »

MySQL 数据文件全解析:存储位置、类型与引擎关联

MySQL 的数据文件是数据持久化的核心载体,不同存储引擎的文件类型、组织结构差异显著。理解数据文件的存储逻辑,对数据库备份、迁移、性能优化至关重要。本文详细梳理数据文件的存储位置、类型及与存储引擎的关联。

数据文件的存储位置

MySQL 所有数据文件(包括数据库、表、日志等)均存储在 datadir 配置指定的目录下,可通过以下命令查询:

1
2
-- 查看数据文件根目录
SHOW VARIABLES LIKE '%datadir%';

目录结构
datadir 下以数据库名创建子目录,每个子目录中存放该数据库内所有表的相关文件。例如:

  • 数据库 test 对应目录:datadir/test/
  • test.user 的文件均位于 test/ 目录下。

核心数据文件类型及功能

不同存储引擎生成的文件类型不同,以下是常见文件的详细说明:

表结构文件:.frm

  • 作用:存储表的元数据(表结构定义),包括字段名、数据类型、长度、约束(如 NOT NULL)、索引定义等。
  • 通用性所有存储引擎都会生成 .frm 文件(与引擎无关)。
  • 特点:
    • 文件名与表名一致(如 user.frm 对应表 user)。
    • MySQL 8.0 后,.frm 文件被合并到 InnoDB 的 .ibd 文件中,不再单独生成。

InnoDB 存储引擎的核心文件

InnoDB 的数据和索引存储在表空间文件中,支持两种表空间模式:独立表空间共享表空间

阅读全文 »