一文彻底弄懂MySQL的各个存储引擎,InnoDB、MyISAM、Memory、CSV、Archive、Merge、Federated、NDB
MySQL 中的存储引擎是其数据库管理系统的核心模块,用于处理不同类型的数据存储和检索操作。每种存储引擎都有自己的特点,适用于不同类型的应用场景。MySQL 最常用的存储引擎包括 InnoDB、MyISAM、Memory、CSV、Archive、Merge、Federated、NDB 等。以下是对 MySQL 存储引擎的详细介绍。
1. InnoDB 存储引擎
主要特点:
- 事务支持:InnoDB 是 MySQL 中默认的存储引擎,支持完整的 ACID 事务(Atomicity, Consistency, Isolation, Durability)特性。它还提供了事务的隔离级别,可以防止脏读、不可重复读、幻读等问题。
- 行级锁定:InnoDB 使用行级锁定(Row-level Locking),这使得它非常适合高并发的写操作,锁冲突的概率较小。
- 外键支持:InnoDB 支持外键约束,因此可以在表与表之间定义数据的依赖关系,并自动维护参照完整性。
- 崩溃恢复:InnoDB 通过使用 重做日志(Redo Logs) 和 撤销日志(Undo Logs) 来保证在系统崩溃时的数据恢复能力。
- 聚簇索引:InnoDB 使用聚簇索引(Clustered Index),主键索引和数据存储在一起。每个表必须有一个主键,如果没有定义主键,InnoDB 会自动生成一个隐藏的主键。
适用场景:
InnoDB 非常适合处理需要高并发的事务系统,例如:
- 银行交易系统:涉及到大量的插入、更新操作,并且需要保证事务的完整性和隔离性。
- 电子商务平台:需要频繁的订单插入和库存更新,并保证数据一致性。
工作机制(底层实现):
- 数据存储结构:InnoDB 将表存储在一个逻辑的表空间中,默认情况下使用共享表空间
ibdata文件,也可以每个表单独存储在自己的.ibd文件中。 - 缓冲池(Buffer Pool):InnoDB 通过缓存数据页的方式,减少磁盘 I/O 操作。修改操作首先会被写入缓冲池,随后异步地刷新到磁盘。
- 双写缓冲(Doublewrite Buffer):为了防止在崩溃或断电时数据部分写入磁盘导致的损坏,InnoDB 将数据页写入两次,确保数据完整。
2. MyISAM 存储引擎
主要特点:
- 不支持事务:MyISAM 不支持事务和外键,因此不能保证数据的完整性和一致性。
- 表级锁定:MyISAM 使用表级锁定(Table-level Locking),对于读操作锁定整个表,写操作也是如此。这使得 MyISAM 的并发性能较差,尤其是在频繁写入的场景。
- 全文索引支持:MyISAM 支持全文索引(Full-text Index),可以用于高效的全文搜索操作。
- 较小的存储空间:MyISAM 的存储格式紧凑,对于存储静态数据或日志数据有一定的优势。
- 速度快:由于其不需要事务控制、外键支持等功能,MyISAM 在只读或读多写少的场景下性能非常好。
适用场景:
- 只读数据库:用于静态数据存储,且更新频率低的场景。例如,数据仓库 或 日志存储系统。
- 全文搜索:需要对文本进行快速全文搜索的场景。
工作机制(底层实现):
- 数据和索引分离存储:MyISAM 将数据存储在
.MYD文件中,索引存储在.MYI文件中。 - 表锁机制:对于 MyISAM,读取操作可以并发进行,但一旦有写操作,整个表会被锁定。写入时会阻塞所有其他的读操作。
- 不支持崩溃恢复:与 InnoDB 不同,MyISAM 不支持崩溃恢复,一旦系统崩溃可能导致数据丢失或不一致。
3. Memory 存储引擎
主要特点:
- 数据存储在内存中:Memory 存储引擎的数据是临时存储在内存中的,重启数据库或关闭会话后,所有数据都会丢失。
- 表级锁定:和 MyISAM 一样,Memory 引擎使用表级锁定。
- 速度快:由于数据完全存储在内存中,Memory 引擎的读写速度非常快。
- 不支持 BLOB 和 TEXT 类型:由于内存的限制,Memory 引擎不支持大对象类型,如 BLOB 和 TEXT 类型。
适用场景:
- 临时数据处理:Memory 引擎适合用于临时数据处理、缓存数据等。例如,临时表 或 会话数据存储。
- 快速查询结果存储:需要高效快速查询但不需要持久化的场景。
工作机制(底层实现):
- 内存存储结构:Memory 引擎将数据存储在内存中,使用哈希索引(Hash Index),以提供更快速的查询性能。
- 数据丢失风险:由于数据存储在内存中,一旦服务器重启或关闭,所有数据都会消失。
4. CSV 存储引擎
主要特点:
- 文本存储:CSV 引擎将数据存储为逗号分隔值的文本文件,类似于传统的 CSV 文件。
- 简单结构:每张表的数据都会被存储在一个
.csv文件中。 - 不支持索引:CSV 引擎不支持索引,因此查询性能较差。
- 便于导入和导出:由于其存储格式是标准的 CSV 文件,便于与外部系统进行数据交换。
适用场景:
- 数据导入和导出:在需要与其他系统交换数据时,CSV 存储引擎是一个很好的选择。
- 临时数据存储:对于需要简单格式且不需要索引的数据存储场景,可以使用 CSV。
5. Archive 存储引擎
主要特点:
- 适合大规模数据存储:Archive 存储引擎专门设计用于高效地存储大量的历史数据或归档数据。
- 支持插入和查询:Archive 只支持插入操作和查询操作,不支持更新和删除操作。
- 数据压缩:Archive 引擎会将数据进行压缩存储,从而减少磁盘占用。
- 表级锁定:Archive 使用表级锁定。
适用场景:
- 日志系统:Archive 存储引擎非常适合存储日志数据,历史归档数据等,数据存储空间有限的场景。
6. 其他存储引擎
- Merge:合并多个 MyISAM 表,可以将多个相同结构的 MyISAM 表合并为一个逻辑表,常用于分区数据管理。
- Federated:用于分布式数据库系统,可以在不同 MySQL 实例之间进行跨服务器查询。
- NDB Cluster:用于 MySQL Cluster 配置,分布式、容错的存储引擎,常用于高可用系统。
总结
| 存储引擎 | 主要特点 | 适用场景 |
|---|---|---|
| InnoDB | 支持事务、行级锁定、外键支持 | 高并发事务系统(如银行、电子商务平台) |
| MyISAM | 不支持事务、表级锁定、全文索引支持 | 静态数据存储、读多写少的系统 |
| Memory | 数据存储在内存中,速度快 | 临时数据处理、缓存、会话管理 |
| CSV | 数据存储为文本文件,便于数据交换 | 数据导入导出场景 |
| Archive | 只支持插入和查询,数据压缩 | 日志数据存储、大规模历史数据归档 |
| Merge | 合并多个 MyISAM 表 | 分区数据管理 |
| Federated | 分布式数据库系统,跨服务器查询 | 需要与其他 MySQL 实例交互的系统 |
一文彻底弄懂MySQL的各个存储引擎,InnoDB、MyISAM、Memory、CSV、Archive、Merge、Federated、NDB的更多相关文章
- [转帖]一文看懂mysql数据库本质及存储引擎innodb+myisam
一文看懂mysql数据库本质及存储引擎innodb+myisam https://www.toutiao.com/i6740201316745740807/ 原创 波波说运维 2019-09-29 0 ...
- mysql 流程函数 存储引擎 InnoDB简单特性
建表及插入数据语句: mysql> create table salary(userid int,salary decimal(9,2)); Query OK, 0 rows affected ...
- MySQL存储引擎 InnoDB/ MyISAM/ MERGE/ BDB 的区别
MyISAM:默认的MySQL插件式存储引擎,它是在Web.数据仓储和其他应用环境下最常使用的存储引擎之一.注意,通过更改 STORAGE_ENGINE 配置变量,能够方便地更改MySQL服务器的默认 ...
- 浅谈MySQL存储引擎-InnoDB&MyISAM
存储引擎在MySQL的逻辑架构中位于第三层,负责MySQL中的数据的存储和提取.MySQL存储引擎有很多,不同的存储引擎保存数据和索引的方式是不同的.每一种存储引擎都有它的优势和劣势,本文只讨论最常见 ...
- mysql常用的存储引擎,MyISAM和InnoDB的对比
Mysql有多种存储引擎,最常用的有MyISAM和InnoDB这两种,每一种类型的存储引擎都有自已的特点,可以结合项目中数据的使用场景来进行了哪种存储引擎合适. 1:查看mysql数据库支持的存储引擎 ...
- MySQL两大存储引擎:MyISAM和InnoDB
Mysql有两大常用的存储引擎MyISAM,InnoDB,默认的形式是前者. 两者基本的差别是对事务处理.外键和行级锁的主持上,InnoDB支持事务处理.外键等高级特性,而MyISAM不支持.MyIS ...
- MySQL两大存储引擎InnoDB与MyISAM
1.InnoDB存储引擎 MySQL5.5中InnoDB成为默认的存储引擎.InnoDB是事务型存储引擎,被设计用来处理大量的短期事务.它的性能和自动崩溃恢复特性,使得它在非事务场景中也很流行. 所以 ...
- MySQL支持多种存储引擎
MySQL的强大之处在于它的插件式存储引擎,我们可以基于表的特点使用不同的存储引擎,从而达到最好的性能. MySQL有多种存储引擎:MyISAM.InnoDB.MERGE.MEMORY(HEAP).B ...
- 百万年薪python之路 -- MySQL数据库之 存储引擎
MySQL之存储引擎 一. 存储引擎概述 定义: 存储引擎是mysql数据库独有的存储数据.为数据建立索引.更新数据.查询数据等技术的实现方法 首先声明一点: 存储引擎这个概念只有MySQL才有. ...
- MySQL的多存储引擎架构
支持多种存储引擎是众所周知的MySQL特性,也是MySQL架构的关键优势之一.如果能够理解MySQL Server与存储引擎之间是怎样通过API交互的,将大大有利于理解MySQL的核心基础架构.本文将 ...
随机推荐
- 解决CGLib动态代理测试不通过-Unable to load cache item
1.背景 在学习aop底层时遇到的问题,做个小结 2.现象 动态代理代码如下: package com.ldp.proxy; import net.sf.cglib.proxy.Enhancer; i ...
- Redis存储数组
建议使用PHP自带的序列化函数serialize和unserialize函数 <?php class MyRedis{ private static $handler; private stat ...
- 8. 从0学ARM-内联汇编、混合汇编、ATPCS规则
一.gcc 内联汇编 内联汇编即在C中直接使用汇编语句进行编程,使程序可以在C程序中实现C语言不能完成的一些工作,例如,在下面几种情况中必须使用内联汇编或嵌入型汇编. 程序中使用饱和算术运算(Satu ...
- MySql 字段类型长度问题理解
mysql中字段长度理解 字符长度 设计表中设置的是字符长度,任意字符都占一个字符长度,使用char_length 函数获取 char_length(`name`) 字节长度 字节长度和数据表的字符集 ...
- Win32 ListCtrl控件点击列标题排序
1.在WM_NOTIFY消息中捕获鼠标点点击列的索引 int MyMainDialog::OnNotify(NMHDR* pNMhdr) { if (pNMhdr->idFrom == IDC_ ...
- 【FFmpeg】之Mac系统爬取所有M3U8视频下载方法
前言 由于有的网站不允许下载视频,到了有效期就不能看了,但是我想以后反复看,怎么办呢? 前提准备 操作系统:Mac 浏览器:谷歌浏览器 抓取m3u8工具:猫爪 视频处理工具:ffmpeg 需要安装工具 ...
- Mono 现状与未来:从Wine-mono 到.NET 9
Mono 官网主页[1]和 Mono GitHub 页面今日发布公告[2],微软宣布将 Mono 项目移交给 WineHQ 组织,也就是 Linux 兼容 Windows 应用框架 Wine 的开发团 ...
- 好多kafka难题啊,看看其中的化解之道
文末有面经共享群 前面已经分享过几篇面试了,这是一篇关于更加面向项目和技术的面经详解,第一次遇见问那么多kafka的问题,看看这个粉丝是怎么回答的. 先来看看 职位描述: 岗位职责: 负责基于 Go ...
- 开发Android应用程序,在Android10的系统上提示网络出错?
今天维护以前开发的一个Android客户端程序,发版后,有用户说自己手机安装,无法登录,首屏打开后(有网络通过接口加载服务器数据并显示的行为),提示网络出错. 但是我在我自己手上的PDA设备(Andr ...
- pyspark 数据类型及转换
spark 有哪些数据类型 https://spark.apache.org/docs/latest/sql-reference.html Spark 数据类型 Data Types Spark SQ ...