Mysql架构与内部模块-第三章
前言
接上文,本篇文章专门简述Mysql存储引擎,内容繁多,如果你只需知道每种存储引擎的适用场景,可以直接查看本文最后列出的适用场景部分。
正文:
Mysql存储引擎作为本系列文章中相对重要的一环,也是相关领域面试官问的比较多的一部分,能够掌握不同的存储引擎的区别,可以让你在工作中有更加突出的表现。
存储引擎首先其实它是一个进程,它能够决定你的数据的存储方式,管理方式,然后提供一些特性。
先带着一个问题进入后面的内容:Mysql为什么要设计如此多的存储引擎?
Mysql存储引擎是一种数据分布格式,从最直观的角度来讲,就是表文件在磁盘上的表现形式不同,文件个数不同,举个例子:
我们新建一张表:member_a,存储引擎选用InnoDB.

然后我们查看member_a表在我们磁盘上的表现:

包含两个文件:member_a.frm以及member_a.ibd ,其中frm文件为表元数据文件,比如表结构等相关信息,那么也就是说,不管你采用什么存储引擎
xxx.frm文件都是必要存在的,因为只要你是一张表,那么在你的磁盘上就会存在tableName.frm。
可以在你数据库发生意外损坏时使用此文件进行恢复,恢复方法我在后续有时间的话也会另开一篇文章进行详细说明各种存储类型的恢复。
ibd文件是存放InnoDB数据的文件,当然也包括索引,除此之外还可能存在一个后缀为.ibdata的文件,此文件和ibd文件相同,那么为什么InnoDB会存在两个不同类型的文件进行数据存储?
实际上InnoDB具有两种存储方式:共享表空间存储(ibdata),独立表空间存储(ibd) ,其可以通过配置来决定。
独立表空间(ibd)为一张表一个xx.ibd文件。
共享表空间(ibdata)可以设置为所有表共享一个或者多个ibdata文件。
共享表空间的相关设置,本文就不做赘述,感兴趣的朋友可以查阅相关资料。
然后我们再使用MyISAM存储引擎创建表:member_b,然后观察此表在磁盘上的结构:


可以看到,除了必须存在的member_b.frm文件外,少了InnoDB引擎专有的xxx.ibd文件,多了MYD和MYI文件。
请注意这两个文件是MyISAM引擎的特有文件,MYD存放表数据,MYI文件存放索引等信息。
然后我们在新增一张使用MEMORY存储引擎的表:member_c:


可以看到,数据目录下,member_c表只存在一个文件:member_c.frm。
以上举例了3种比较常见的Mysql存储引擎,在Mysql5.7以上的版本中,在创建表时,如果不指定表的存储引擎,那么默认为InnoDB引擎,下面将列出Mysql5.7全部的
存储引擎列表及详细说明
Mysql的存储引擎分为以下种类:
InnoDB存储引擎(5.7以上默认引擎)
MyISAM存储引擎
MEMORY存储引擎
CSV存储引擎
ARCHIVE存储引擎
BLACKHOLE存储引擎
MERGE存储引擎
FEDERATED存储引擎
EXAMPLE存储引擎
第三方存储引擎(社区或者如果你对C语言非常熟悉,你可以根据Mysql提供的接口规范,自己写上一个存储引擎,那你是非常牛逼的,从这个地方其实也可以看出来,为什么
我们的表在创建的时候指定了存储引擎,在后续还能够修改为不同的存储引擎,因为这些存储引擎都实现了同一套接口,跟JAVA为什么能够支持这么多数据库一样的道理,
因为都实现了JDK提供的接口。)
以上例举了Mysql目前支持的存储引擎,可以看到种类繁多,他们的运用场景也大不相同,下面我们聊聊每种存储引擎的不同:
InnoDB存储引擎
InnoDB是一款高性能和高可用兼并的通用存储引擎,在Mysql5.7以上,如果你在创建表时,不指定ENGINE为其他引擎,那么默认将创建一个InnoDB引擎的表,
InnoDB表的DML操作遵循ACID模型,并且支持事物(提交,回滚,崩溃恢复),以保证用户的数据安全,支持行级锁定和Oracle风格的一致读取,保证了多用户并发和性能。
InnoDB表会将你的数据安排在磁盘上,并基于主键优化查询,每个InnoDB表都有一个称之为 聚集索引 的主键索引,这个索引将组织数据以最小化主键查找的I/O.
InnoDB支持MVCC,其实就是一致性非锁定读的技术,这个内容我们后续有时间会聊聊。
InnoDB支持外键。
InnoDB存储引擎适用场景总结:适用于需要经常修改和插入,对并发和QPS要求较高,且对数据一致性要求较高的表。
以下是InnoDB在5.7版本中支持的功能:
| 特征 | 支持 |
|---|---|
| B树索引 | 是 |
| 备份/时间点恢复(在服务器中而不是在存储引擎中实现。) | 是 |
| 集群数据库支持 | 没有 |
| 聚集索引 | 是 |
| 压缩数据 | 是 |
| 资料快取 | 是 |
| 加密数据 | 是(通过加密功能在服务器中实现;在MySQL 5.7和更高版本中,支持静态数据表空间加密。) |
| 外键支持 | 是 |
| 全文搜索索引 | 是(MySQL 5.6和更高版本提供InnoDB对FULLTEXT索引的支持。) |
| 地理空间数据类型支持 | 是 |
| 地理空间索引支持 | 是(MySQL 5.7和更高版本提供InnoDB对地理空间索引的支持。) |
| 哈希索引 | 否(InnoDB在内部将哈希索引用于其自适应哈希索引功能。) |
| 索引缓存 | 是 |
| 锁定粒度 | 行 |
| MVCC | 是 |
| 复制支持(在服务器中而不是在存储引擎中实现。) | 是 |
| 储存限制 | 64TB |
| T树索引 | 没有 |
| 交易次数 | 是 |
| 更新数据字典的统计信息 | 是 |
MyISAM存储引擎
MyISAM引擎是基于老旧的ISAM存储引擎优化后的成果,使用MyISAM存储引擎的表具有以下特点:
所有的数据值都是以低字节存储,此特征可能不太适用于一些特殊的嵌入式系统。
所有的数字键值都先存储高字节,这要可以实现更好的索引压缩。
支持大文件。
MyISAM存储引擎的表,最大的索引数量为64,一个索引最多能够关联16列。
支持并发插入。
支持把数据文件和索引文件放在不同的物理机中。
不支持事务。
不支持外键。
MyISAM存储引擎试用场景总结:适用于大量读写,不需要外键约束,不需要事务的表。
以下是InnoDB在5.7版本中支持的功能:
| 特征 | 支持 |
|---|---|
| B树索引 | 是 |
| 备份/时间点恢复(在服务器中而不是在存储引擎中实现。) | 是 |
| 集群数据库支持 | 没有 |
| 聚集索引 | 没有 |
| 压缩数据 | 是(仅当使用压缩行格式时才支持压缩MyISAM表。将压缩行格式与MyISAM一起使用的表是只读的。) |
| 资料快取 | 没有 |
| 加密数据 | 是(通过加密功能在服务器中实现。) |
| 外键支持 | 没有 |
| 全文搜索索引 | 是 |
| 地理空间数据类型支持 | 是 |
| 地理空间索引支持 | 是 |
| 哈希索引 | 没有 |
| 索引缓存 | 是 |
| 锁定粒度 | 表 |
| MVCC | 没有 |
| 复制支持(在服务器中而不是在存储引擎中实现。) | 是 |
| 储存限制 | 256TB |
| T树索引 | 没有 |
| 交易次数 | 没有 |
| 更新数据字典的统计信息 | 是 |
因篇幅问题,今日暂时先介绍两种存储引擎,明日将带来后续几种存储引擎的介绍。
FEDERATED
Mysql架构与内部模块-第三章的更多相关文章
- Mysql架构与内部模块-第一章
Mysql作为大多数中小型企业的首选数据库,也可能是众多同僚接触的第一个数据库,其热门程度不言而喻,一些相对基础的知识本系列不做赘述,主要简述Mysql相关的进阶知识. 本章将由浅入深的讲解从连接My ...
- Mysql架构与内部模块-第二章
接上文,上文简述到了Mysql中的查询缓存和解析器,今日我们继续. 先来看一段SQL:SELECT * FROM `jianghuadong`; 先假设我们数据库中并没有一张名为jianghuadon ...
- Mysql必知必会 第三章 使用Mysql
第三章 使用Mysql SQL语句和大小写 请注意,SQL语句不区分大小写,因此SELECT与select是相同的.同样,写成Select也没有关系.许多SQL开发人员喜欢对所有SQL关键字使用大写, ...
- .net架构设计读书笔记--第三章 第9节 域模型实现(ImplementingDomain Model)
我们长时间争论什么方案是实现域业务领域层架构的最佳方法.最后,我们用一个在线商店案例来说明,其中忽略了许多之前遇到的一些场景.在线商店对很多人来说更容易理解. 一.在线商店项目简介 1. 用例 ...
- .net架构设计读书笔记--第三章 第8节 域模型简介(Introducing Domain Model)
一.数据--行为转变 很长的时间,典型的分析方法或多或少是以下两种,第一,收集需求并做一些分析,找出有关实体 (例如,客户. 订单. 产品) 和进程来实现. 第二,手持这种理解你尝试推断一个物 ...
- .net架构设计读书笔记--第三章 第10节 命令职责分离(CQRS)简介(Introducing CQRS)
一.分离查询命令 Separating commands from queries 早期的面向DDD设计方法的难点是如何设计一个类,这个类要包含域的方方面面.通常来说,任务软件系统方法调用可以 ...
- 打通MySQL架构和业务的任督二脉
目前,在很多OLTP场景中,MySQL数据库都有着广泛的应用,也有很多不同的使用方式.从数据库的业务需求.架构设计.运营维护.再到扩容迁移,不同的MySQL架构有不同的特点,适应一定的业务场景,或者解 ...
- 纲举目张:打通MySQL架构和业务的任督二脉
目前,在很多OLTP场景中,MySQL数据库都有着广泛的应用,也有很多不同的使用方式.从数据库的业务需求.架构设计.运营维护.再到扩容迁移,不同的MySQL架构有不同的特点,适应一定的业务场景,或者解 ...
- 第 2 章 MySQL 架构组成
麻雀虽小,五脏俱全.MySQL 虽然以简单著称,但其内部结构并不简单.本章从MySQL物理组成.逻辑组成,以及相关工具几个角度来介绍 MySQL 的整体架构组成,希望能够让读者对 MySQL 有一个更 ...
随机推荐
- 【盗墓笔记】图解使用fat-aar方式在AndroidStudio中打包嵌套第三方aar的aar
将一些项目中的一些独立功能打包成aar,不仅能于项目解耦,还能够提供给其它项目使用相同的功能,可谓是为项目开发带来了很大的便利.最近第一次做sdk,碰到一些问题,花了不少时间才解决,所以这里做一下简单 ...
- Linux设备驱动模型简述(源码剖析)
1. Linux设备驱动模型和sysfs文件系统 Linux内核在2.6版本中引入设备驱动模型,简化了驱动程序的编写.Linux设备驱动模型包含设备(device).总线(bus).类(class)和 ...
- oracle之分组函数
分组函数 5.1 最重要的五个分组函数 sum(); avg(); count(); max(); min(). 数值类型可以使用所有组函数SQL> select sum(sal) sum, a ...
- Sql Server中使用特定字符分割字符串
在T-SQL中我们经常批量操作时都会对字符串进行拆分,可是SQL Server中却没有自带Split函数,所以要自己来实现了.这里将字符串分割以table形式输出 语法如下: SET ANSI_NUL ...
- js监听事件的绑定与移除
监听事件的绑定与移除主要是addEventListener和removeEventListener的运用. addEventListener语法 element.addEventListener(ty ...
- 第 8 篇:内容支持 Markdown 语法,接口返回包含解析后的 HTML
作者:HelloGitHub-追梦人物 在 Django博客教程(第二版) 中,我们给博客内容增加了 Markdown 的支持,博客详情接口应该返回解析后的 HTML 内容. 来回顾一下 Post 模 ...
- mariadb 3
MariaDB第三章(select) 基本查询 --查询基本使用(条件,排序,聚合函数,分组,分页) --创建学生表 create table students ( id int unsigned ...
- JVM参数总结
官方文档 堆参数: -Xms: 堆的初始值,例如 -Xmx2048,初始堆大小为 2G -Xmx: 堆的最大值,例如 -Xmx2048M,允许最大堆内存 2G -Xmn: 新生代大小 -XX:Surv ...
- 基础篇:JVM运行时内存布局
目录 1 JVM的内存区域布局 2 JVM五大数据区域介绍 3 JVM运行时内存布局和JMM内存模型区别 4 JMM内存模型交互操作 欢迎指正文中错误 关注公众号,一起交流 参考文章 1 JVM的内存 ...
- Android捕捉错误try catch 的简单使用
基本语法 try{ //可能发生错误的程式码 }catch(具体错误 e){ //具体错误有就写,没有就不写,有多个,就写多个catch e.printStackTrace(); //在命令行打印错误 ...