Mysql中存储引擎的区别及比较


Posted in MySQL onJune 04, 2021

MyISAM存储引擎

MyISAM基于ISAM存储引擎,并对其进行扩展。它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。MyISAM拥有较高的插入、查询速度,但不支持事务

MyISAM主要特性有:

1、大文件(达到63位文件长度)在支持大文件的文件系统和操作系统上被支持。

2、当把删除和更新及插入操作混合使用的时候,动态尺寸的行产生更少碎片。这要通过合并相邻被删除的块,以及若下一个块被删除,就扩展到下一块自动完成。

3、每个MyISAM表最大索引数是64,这可以通过重新编译来改变。每个索引最大的列数是16

4、NULL被允许在索引的列中,这个值占每个键的0~1个字节

5、可以把数据文件和索引文件放在不同目录(InnoDB是放在一个目录里面的)

MyISAM引擎使用B+Tree作为索引结构,叶节点的data域存放的是数据记录的地址

下图是MyISAM索引的原理图:

Mysql中存储引擎的区别及比较

这里设表一共有三列,假设我们以Col1为主键,则上图是一个MyISAM表的主索引(Primary key)示意。

可以看出MyISAM的索引文件仅仅保存数据记录的地址

在MyISAM中,主索引和辅助索引(Secondary key)在结构上没有任何区别,只是主索引要求key是唯一的,而辅助索引的key可以重复。

如果我们在Col2上建立一个辅助索引,则此索引的结构如下图所示:

Mysql中存储引擎的区别及比较

同样也是一颗B+Tree,data域保存数据记录的地址。

因此,MyISAM中索引检索的算法为首先按照B+Tree搜索算法搜索索引,如果指定的Key存在,则取出其data域的值,然后以data域的值为地址,读取相应数据记录。

MyISAM的索引方式也叫做“非聚集”的,之所以这么称呼是为了与InnoDB的聚集索引区分。

InnoDB存储引擎

InnoDB是事务型数据库的首选引擎,支持事务安全表(ACID),支持行锁定外键,上图也看到了,InnoDB是默认的MySQL引擎

InnoDB主要特性有:

1、InnoDB给MySQL提供了具有提交、回滚和崩溃恢复能力的事物安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句中提供一个类似Oracle的非锁定读。这些功能增加了多用户部署和性能。在SQL查询中,可以自由地将InnoDB类型的表和其他MySQL的表类型混合起来,甚至在同一个查询中也可以混合

2、InnoDB是为处理巨大数据量的最大性能设计。它的CPU效率可能是任何其他基于磁盘的关系型数据库引擎锁不能匹敌的

3、InnoDB存储引擎完全与MySQL服务器整合,InnoDB存储引擎为在主内存中缓存数据和索引而维持它自己的缓冲池。InnoDB将它的表和索引在一个逻辑表空间中,表空间可以包含数个文件(或原始磁盘文件)。这与MyISAM表不同,比如在MyISAM表中每个表被存放在分离的文件中。InnoDB表可以是任何尺寸,即使在文件尺寸被限制为2GB的操作系统上

4、InnoDB支持外键完整性约束,存储表中的数据时,每张表的存储都按主键顺序存放,如果没有显示在表定义时指定主键,InnoDB会为每一行生成一个6字节的ROWID,并以此作为主键。

虽然InnoDB也使用B+Tree作为索引结构,但具体实现方式却与MyISAM截然不同。

第一个重大区别是InnoDB的数据文件本身就是索引文件

从 上文知道,MyISAM索引文件和数据文件是分离的,索引文件仅保存数据记录的地址。

而在InnoDB中,表数据文件本身就是按B+Tree组织的一个索 引结构,这棵树的叶节点data域保存了完整的数据记录

这个索引的key是数据表的主键,因此InnoDB表数据文件本身就是主索引。

Mysql中存储引擎的区别及比较

上图是InnoDB主索引(同时也是数据文件)的示意图,可以看到叶节点包含了完整的数据记录。

这种索引叫做聚集索引。因为InnoDB的数据文件本身 要按主键聚集,所以InnoDB要求表必须有主键(MyISAM可以没有),如果没有显式指定,则MySQL系统会自动选择一个可以唯一标识数据记录的列 作为主键,如果不存在这种列,则MySQL自动为InnoDB表生成一个隐含字段作为主键,这个字段长度为6个字节,类型为长整形。

第二个与MyISAM索引的不同是InnoDB的辅助索引data域存储相应记录主键的值而不是地址。换句话说,InnoDB的所有辅助索引都引用主键作为data域。

例如,下图为定义在Col3上的一个辅助索引:

Mysql中存储引擎的区别及比较

这里以英文字符的ASCII码作为比较准则。聚集索引这种实现方式使得按主键的搜索十分高效,但是辅助索引搜索需要检索两遍索引:首先检索辅助索引获得主键,然后用主键到主索引中检索获得记录

了 解不同存储引擎的索引实现方式对于正确使用和优化索引都非常有帮助,例如知道了InnoDB的索引实现后,就很容易明白为什么不建议使用过长的字段作为 主键,因为所有辅助索引都引用主索引,过长的主索引会令辅助索引变得过大。

再例如,用非单调的字段作为主键在InnoDB中不是个好主意,因为 InnoDB数据文件本身是一颗B+Tree,非单调的主键会造成在插入新记录时数据文件为了维持B+Tree的特性而频繁的分裂调整,十分低效,而使用 自增字段作为主键则是一个很好的选择。

MEMORY存储引擎

MEMORY存储引擎将表中的数据存储到内存中,未查询和引用其他表数据提供快速访问。

MEMORY主要特性有:

1、MEMORY表的每个表可以有多达32个索引,每个索引16列,以及500字节的最大键长度

2、MEMORY存储引擎执行HASH和BTREE缩影

3、可以在一个MEMORY表中有非唯一键值

4、MEMORY表使用一个固定的记录长度格式

5、MEMORY不支持BLOB或TEXT列

6、MEMORY支持AUTO_INCREMENT列和对可包含NULL值的列的索引

7、MEMORY表在所由客户端之间共享(就像其他任何非TEMPORARY表)

8、MEMORY表内存被存储在内存中,内存是MEMORY表和服务器在查询处理时的空闲中,创建的内部表共享

9、当不再需要MEMORY表的内容时,要释放被MEMORY表使用的内存,应该执行DELETE FROM或TRUNCATE TABLE,或者删除整个表(使用DROP TABLE)

Archive存储引擎 存储引擎的选择

不同的存储引擎都有各自的特点,以适应不同的需求,如下表所示:

Mysql中存储引擎的区别及比较

InnoDB :如果要提供提交、回滚、崩溃恢复能力的事务安全(ACID兼容)能力,并要求实现并发控制,InnoDB是一个好的选择

InnoDB 和 MyISAM之间的区别:

1>.InnoDB支持事物,而MyISAM不支持事物

2>.InnoDB支持行级锁,而MyISAM支持表级锁

3>.InnoDB支持MVCC, 而MyISAM不支持

4>.InnoDB支持外键,而MyISAM不支持

5>.InnoDB不支持全文索引,而MyISAM支持。(X)

MyISAM:如果数据表主要用来插入和查询记录,则MyISAM(但是不支持事务)引擎能提供较高的处理效率

Memory:如果只是临时存放数据,数据量不大,并且不需要较高的数据安全性,可以选择将数据保存在内存中的Memory引擎,MySQL中使用该引擎作为临时表,存放查询的中间结果。数据的处理速度很快但是安全性不高。

Archive:如果只有INSERT和SELECT操作,可以选择Archive,Archive支持高并发的插入操作,但是本身不是事务安全的。Archive非常适合存储归档数据,如记录日志信息可以使用Archive

使用哪一种引擎需要灵活选择,一个数据库中多个表可以使用不同引擎以满足各种性能和实际需求,使用合适的存储引擎,将会提高整个数据库的性能

以上为个人经验,希望能给大家一个参考,也希望大家多多支持三水点靠木。

MySQL 相关文章推荐
MySQL中distinct与group by之间的性能进行比较
May 26 MySQL
MySQL通过binlog恢复数据
May 27 MySQL
zabbix监控mysql的实例方法
Jun 02 MySQL
MySQL 5.7常见数据类型
Jul 15 MySQL
MySQL深度分页(千万级数据量如何快速分页)
Jul 25 MySQL
分享mysql的current_timestamp小坑及解决
Nov 27 MySQL
VS2019连接MySQL数据库的过程及常见问题总结
Nov 27 MySQL
MySQL数据库⾼可⽤HA实现小结
Jan 22 MySQL
MySQL的索引你了解吗
Mar 13 MySQL
MySQL中一条update语句是如何执行的
Mar 16 MySQL
MySQL时区造成时差问题
Apr 13 MySQL
mysql数据库如何转移到oracle
Dec 24 MySQL
浅谈mysql返回Boolean类型的几种情况
Jun 04 #MySQL
Mysql 设置boolean类型的操作
Jun 04 #MySQL
MySQL中的布尔值,怎么存储false或true
mysql外连接与内连接查询的不同之处
Mysql systemctl start mysqld报错的问题解决
Jun 03 #MySQL
你知道哪几种MYSQL的连接查询
Jun 03 #MySQL
MySQL中in和exists区别详解
Jun 03 #MySQL
You might like
php 格式化数字的时候注意数字的范围
2010/04/13 PHP
php 获取SWF动画截图示例代码
2014/02/10 PHP
php使用fgetcsv读取csv文件出现乱码的解决方法
2014/11/08 PHP
php操作redis常见方法示例【key与value操作】
2020/04/14 PHP
JavaScript写的一个DIV 弹出网页对话框
2009/08/14 Javascript
如何让div span等元素能响应键盘事件操作指南
2012/11/13 Javascript
js时间日期和毫秒的相互转换
2013/02/22 Javascript
js 调用父窗口的具体实现代码
2013/07/15 Javascript
jQuery实现可收缩展开的级联菜单实例代码
2013/11/27 Javascript
使用script的src实现跨域和类似ajax效果
2014/11/10 Javascript
jQuery搜索子元素的方法
2015/02/10 Javascript
JavaScript控制两个列表框listbox左右交换数据的方法
2015/03/18 Javascript
JavaScript中this的四个绑定规则总结
2016/09/26 Javascript
基于angularJS的表单验证指令介绍
2016/10/21 Javascript
值得分享和收藏的xmlplus组件学习教程
2017/05/05 Javascript
React-Native中禁用Navigator手势返回的示例代码
2017/09/09 Javascript
JS计算两个数组的交集、差集、并集、补集(多种实现方式)
2019/05/21 Javascript
js中调用微信的扫描二维码功能的实现代码
2020/04/11 Javascript
Python中文字符串截取问题
2015/06/15 Python
Python 创建新文件时避免覆盖已有的同名文件的解决方法
2018/11/16 Python
Python socket模块实现的udp通信功能示例
2019/04/10 Python
wxPython实现分隔窗口
2019/11/19 Python
pytorch masked_fill报错的解决
2020/02/18 Python
在pycharm中关掉ipython console/PyDev操作
2020/06/09 Python
一文带你了解Python 四种常见基础爬虫方法介绍
2020/12/04 Python
Happy Socks英国官网:购买五颜六色的袜子
2020/11/03 全球购物
军校制空专业毕业生自我鉴定
2013/11/16 职场文书
文明礼仪事迹材料
2014/01/09 职场文书
水电工岗位职责
2014/02/12 职场文书
优秀医生事迹材料
2014/02/12 职场文书
出售房屋协议书范本
2014/10/06 职场文书
学校食堂食品安全承诺书
2015/04/29 职场文书
CAD实训总结范文
2015/08/03 职场文书
导游词之苏州寒山寺
2019/12/05 职场文书
Python Pandas知识点之缺失值处理详解
2021/05/11 Python
oracle索引总结
2021/09/25 Oracle