MySQL 存储引擎概览(最新推荐)

 更新时间:2026年02月05日 10:27:55   作者:@ chen  
MySQL 的存储引擎(Storage Engine)决定了数据如何存储、索引如何组织、事务是否支持、锁的粒度、崩溃恢复能力等,是数据库性能与可靠性的核心,本文给大家介绍MySQL 存储引擎概览,感兴趣的朋友跟随小编一起看看吧

MySQL存储引擎(Storage Engine)决定了数据如何存储、索引如何组织、事务是否支持、锁的粒度、崩溃恢复能力等,是数据库性能与可靠性的核心。

一、常见存储引擎对比(重点)

1. InnoDB(默认 / 首选)

特性

  • 支持事务(ACID)
  • 行级锁(并发能力强)
  • 支持外键
  • 崩溃恢复(redo / undo log)
  • 聚簇索引(数据即索引)

适用场景

  • 业务系统(ERP / 电商 / 金融)
  • 高并发写入
  • 对一致性、可靠性要求高

关键词(面试高频)

  • MVCC
  • Redo Log / Undo Log
  • 行锁 vs 间隙锁
  • Buffer Pool

2. MyISAM(已逐渐淘汰)

特性

  • 不支持事务
  • 表级锁
  • 读性能好
  • 表损坏风险高
  • 数据与索引分离(MYD / MYI)

适用场景

  • 只读或读多写少
  • 历史系统、统计类查询

MySQL 8.x 中已不推荐使用

3. Memory(内存表)

特性

  • 数据存放在内存
  • 默认 Hash 索引(也支持 B-Tree)
  • 重启即丢数据
  • 表级锁

适用场景

  • 临时表
  • 高速缓存表
  • 中间计算结果

4. Archive(归档引擎)

特性

  • 高压缩比
  • 只支持 INSERT / SELECT
  • 不支持索引(除自增)

适用场景

  • 日志归档
  • 审计数据
  • 历史冷数据

5. CSV

特性

  • 数据以 CSV 文件形式存储
  • 无索引、无事务

适用场景

  • 与外部系统做数据交换
  • ETL 中转

二、核心差异对比表

特性InnoDBMyISAMMemoryArchive
事务
锁粒度行锁表锁表锁行锁
崩溃恢复
外键
索引结构B+Tree(聚簇)B+TreeHash / B+Tree
默认引擎

三、如何查看和设置存储引擎

查看当前支持的引擎

SHOW ENGINES;

查看表的存储引擎

SHOW TABLE STATUS WHERE Name = 'user';

建表时指定引擎

CREATE TABLE user (
  id BIGINT PRIMARY KEY,
  name VARCHAR(50)
) ENGINE=InnoDB;

四、选型建议(实战经验)

  • 99% 的业务表:InnoDB
  • 缓存 / 临时数据:Memory
  • 日志 / 历史数据:Archive
  • 不要在新系统使用 MyISAM

五、面试一句话总结

InnoDB 是 MySQL 的事实标准存储引擎,核心优势是事务、行锁、MVCC 和高可靠性;其他引擎只在特定场景使用。

到此这篇关于MySQL 存储引擎概览的文章就介绍到这了,更多相关mysql存储引擎内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql实用操作之日期格式化例子

    mysql实用操作之日期格式化例子

    这篇文章主要给大家介绍了关于mysql实用操作之日期格式化的相关资料,DATE_FORMAT()函数用于格式化MySQL中的日期和时间字段,支持多种格式化选项,需要的朋友可以参考下
    2024-11-11
  • MySQL InnoDB引擎的缓存特性详解

    MySQL InnoDB引擎的缓存特性详解

    这篇文章主要介绍了MySQL InnoDB引擎的缓存特性详解的相关资料,需要的朋友可以参考下
    2022-09-09
  • mysql联合索引最左匹配原则的底层实现原理解读

    mysql联合索引最左匹配原则的底层实现原理解读

    这篇文章主要介绍了mysql联合索引最左匹配原则的底层实现原理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • sql面试题(查看数据中指定几行记录)

    sql面试题(查看数据中指定几行记录)

    一个不错的sql面试题,表 table1,主键为 ID,ID为自动编号(ID可能不连续),要求查询第31-40行记录,如何实现呢?感兴趣的朋友参考下
    2014-05-05
  • MySQL表的内外连接和视图使用实战练习

    MySQL表的内外连接和视图使用实战练习

    这篇文章主要给大家介绍了关于MySQL表的内外连接和视图使用的相关资料,MySQL的内外连接查询是用于将两个或多个表中的数据进行关联查询的一种方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • mysql查询结果命令行方式导出/输出/写入到文件的3种方法举例

    mysql查询结果命令行方式导出/输出/写入到文件的3种方法举例

    这篇文章主要给大家介绍了关于mysql查询结果命令行方式导出/输出/写入到文件的3种方法, 在使用MySQL进行数据库操作的过程中,我们经常需要将查询结果导出到文件中以备后续分析和处理,需要的朋友可以参考下
    2023-08-08
  • MySQL深度分页问题的三种解决方法

    MySQL深度分页问题的三种解决方法

    在 MySQL 中解决深度分页问题的核心思路是减少扫描的数据量,尤其是避免通过 LIMIT offset, size 导致的大范围数据扫描,以下是三种优化方法及其原理、适用场景和注意事项,需要的朋友可以参考下
    2025-02-02
  • Mysql的复合索引如何生效

    Mysql的复合索引如何生效

    本文主要介绍了Mysql的复合索引如何生效,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • mysql不走索引的几个问题小结

    mysql不走索引的几个问题小结

    MySQL中不走索引的问题通常发生在查询中使用了函数,这会使索引失效,从而影响查询性能,本文就介绍了mysql不走索引的几个问题小结,感兴趣的可以了解一下
    2023-08-08
  • mysql数据库找不到表的问题及解决

    mysql数据库找不到表的问题及解决

    这篇文章主要介绍了mysql数据库找不到表的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12

最新评论