SQL进阶笔记 · 第1篇:存储引擎

存储引擎是什么

存储引擎是 MySQL 中负责数据的存储、读取、管理以及索引、事务、锁等功能的底层软件组件。

简单理解:存储引擎决定了数据在硬盘或内存中"怎么存、怎么查、怎么维护"。

核心特点:

  • 插件式架构:MySQL 支持多种存储引擎,可以在表级别指定(一个数据库中不同表可以用不同引擎)。

  • 默认引擎:MySQL 5.5 之前是 MyISAM,之后是 InnoDB。


InnoDB

InnoDB 引擎提供了对数据库 ACID 事务的支持,并且还提供了行级锁和外键的约束。它的设计目标就是处理大数据容量的数据库系统。

可以理解为:"一个带事务、高并发、崩溃恢复能力的数据库操作系统"。MySQL 5.5以后默认引擎。

复制代码
它内部包含:
- 内存管理
- 日志系统
- 锁系统
- 崩溃恢复
- 页管理
- B+树索引
- MVCC

InnoDB 本质:

复制代码
内存(Buffer Pool)
+
日志系统(redo/undo)
+
B+树
+
锁系统
+
MVCC

InnoDB整体架构

复制代码
客户端SQL
↓
SQL解析
↓
执行器
↓
InnoDB
    │
    ├── Buffer Pool(内存缓存)
    ├── redo log(重做日志)
    ├── undo log(回滚日志)
    ├── change buffer
    ├── double write
    ├── lock system
    └── flush刷盘
↓
磁盘.ibd文件

MyISAM 引擎

原本 MySQL 的默认引擎,不提供事务的支持,也不支持行级锁和外键。现在基本淘汰。


最大问题是只有表锁

UPDATE user SET name='A' WHERE id=1,直接锁整张表,并发很差。


不支持事务

sql 复制代码
-- 示例:
BEGIN;
UPDATE A;
UPDATE B;
ROLLBACK;

MyISAM 会忽略 BEGIN、COMMIT、ROLLBACK、SAVEPOINT 等事务相关语句(不会报错,也不会开启事务)。

  • BEGIN 在 MyISAM 中不会生效。
  • UPDATE A; 执行后,立刻、永久修改磁盘上的数据。
  • 没有事务日志(undo log),所以改完就改完了,无法撤销。
  • UPDATE B; 同样,执行完后立即持久化。
  • ROLLBACK; 在这里毫无作用。
  • 因为前两个 UPDATE 已经被"硬提交"了,ROLLBACK 无法撤销它们。

MEMORY引擎

所有的数据都在内存中,不是磁盘。数据的处理速度快,但是安全性不高。

最大问题是重启数据丢失。只有表锁。数据太大内存吃不消。

默认是HASH索引,优点等值查询极快,缺点范围查询差。


对比

特性 InnoDB MyISAM MEMORY
事务
行锁
表锁
MVCC
外键
崩溃恢复
数据存储 磁盘 磁盘 内存
重启保留数据
默认索引 B+树 B+树 HASH
并发能力
当前主流 ⭐⭐⭐⭐⭐ ⭐⭐
相关推荐
段ヤシ.1 小时前
【Java框架】知识点汇总Day7:Spring Boot +Vue(持续更新)
vue.js·spring boot·后端·框架
科技互联.1 小时前
2026轻量化图形引擎白皮书:PG官网发布渠道与分布式PG数据库架构解析
数据库·分布式·数据库架构
雨落在了我的手上1 小时前
Java数据结构(一):初识集合框架
java·开发语言
码语智行1 小时前
Spring Security自定义AuthenticationManager实现手机号/密码双认证
java·后端·spring
SuniaWang1 小时前
《AgentX 专栏》07-全链路可观测:用OpenTelemetry+Jaeger让每次AI对话都可追踪可复盘
java·人工智能·spring·架构·langchain·opentelemetry·agenx
fengxin_rou1 小时前
【从零开始的JUC并发第五章】:线程池详解
java·jvm·spring
爱喝水的鱼丶1 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇)第二篇:SAP 报表数据筛选优化:选择屏幕自定义与查询效率提升
开发语言·数据库·学习·性能优化·sap·abap
咖啡八杯1 小时前
GoF设计模式——装饰模式
java·算法·设计模式·装饰器模式
_Aaron___1 小时前
RAG 知识库越用越脏?先把“增量更新”设计清楚
java·人工智能