面试突击:MySQL 常用引擎有哪些?

系统运维2025-11-05 07:15:035994

MySQL 有很多存储引擎(也叫数据引擎),面试所谓的突击存储引擎是指用于存储、处理和保护数据的用引核心服务。也就是面试存储引擎是数据库的底层软件组织。在 MySQL 中可以使用“show engines”来查询数据库的突击所有存储引擎,如下图所示:

在上述列表中,用引我们最常用的面试存储引擎有以下 3 种:

InnoDBMyISAMMEMORY

下面我们分别来看。

1.InnoDB

InnoDB 是突击 MySQL 5.1 之后默认的存储引擎,它支持事务、用引支持外键、面试支持崩溃修复和自增列。突击如果对业务的用引完整性要求较高,比如张三给李四转账,面试需要减张三的突击钱,同时给李四加钱,用引这时候只能全部执行成功或全部执行失败,此时可以通过 InnoDB 来控制事务的提交和回滚,从而保证业务的完整性。

优缺点分析

InnoDB 的优势是亿华云计算支持事务、支持外键、支持崩溃修复和自增列;它的缺点是读写效率较差、占用的数据空间较大。

2.MyISAM

MyISAM 是 MySQL 5.1 之前默认的数据库引擎,读取效率较高,占用数据空间较少,但不支持事务、不支持行级锁、不支持外键等特性。因为不支持行级锁,因此在添加和修改操作时,会执行锁表操作,所以它的写入效率较低。

优缺点分析

MyISAM 引擎保存了单独的索引文件 .myi,且它的索引是直接定位到 OFFSET 的,而 InnoDB 没有单独的物理索引存储文件,且 InnoDB 索引寻址是先定位到块数据,再定位到行数据,所以 MyISAM 的查询效率是云服务器提供商比 InnoDB 的查询效率要高。但它不支持事务、不支持外键,所以它的适用场景是读多写少,且对完整性要求不高的业务场景。

3.MEMORY

内存型数据库引擎,所有的数据都存储在内存中,因此它的读写效率很高,但 MySQL 服务重启之后数据会丢失。它同样不支持事务、不支持外键。MEMORY 支持 Hash 索引或 B 树索引,其中 Hash 索引是基于 key 查询的,因此查询效率特别高,但如果是基于范围查询的效率就比较低了。而前面两种存储引擎是基于 B+ 树的数据结构实现了。

优缺点分析

MEMORY 读写性能很高,但 MySQL 服务重启之后数据会丢失,它不支持事务和外键。适用场景是读写效率要求高,服务器租用但对数据丢失不敏感的业务场景。

4.查看和设置存储引擎

4.1 查看存储引擎

存储引擎的设置粒度是表级别的,也就是每张表可以设置不同的存储引擎,我们可以使用以下命令来查询某张表的存储引擎:

如下图所示:

4.2 设置存储引擎

在创建一张表的时候设置存储引擎:

修改一张已经存在表的存储引擎:

总结

MySQL 中最常见的存储引擎有:InnoDB、MyISAM 和 MEMORY,其中 InnoDB 是 MySQL 5.1 之后默认的存储引擎,它支持事务、支持外键、支持崩溃修复和自增列,它的特点是稳定(能保证业务的完整性),但数据的读写效率一般;而 MyISAM 的查询效率较高,但不支持事务和外键;MEMORY 的读写效率最高,但因为数据都保存在内存中的,所以 MySQL 服务重启之后数据就会丢失,因此它只适用于数据丢失不敏感的业务场景。

本文地址:http://www.bzve.cn/news/07d1399979.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

掌握Mac电脑新系统的技巧与窍门(从入门到精通,轻松驾驭Mac电脑新系统)

如何将Ubuntu Desktop变为Ubuntu Server服务器版?

iPhone史上最复杂的攻击链,卡巴斯基曝光苹果处理器“神秘后门”

Redis实战之Lettuce使用技巧详解,真香!

如何正确搬运台式电脑机箱(操作指南和注意事项)

数据库产品用什么抓住用户

为提高查询速度建立索引

移动加密流量分类识别研究

友情链接

滇ICP备2023006006号-39