几种数据库存储引擎的对比

举报
炒香菇的书呆子 发表于 2022/02/14 00:20:15 2022/02/14
【摘要】 几种数据库存储引擎对比

Mysql存储引擎简介

存储引擎的概念是MySQL 的特点,而且是一种插入式的存储引擎概念。这决定了MySQL数据库中的表可以用不同的方式存倍。用户可以根据自己的需求,选择不同的存储方式、是否进行驶入处理等。

使用SHOW ENGINES 语句杳看系统所支持的引擎类型

image-20220213235141085

结果中主要参数介绍如下。
Engine参数:指存储引擎的名称。
Support参数:说明MySQL是否支持该类引擎。

Comment参数:指对该引擎的评论。
Transactions参数:表示是否支持事务处理,YES表示可以使用,NO表示不能使用。

XA参数:表示是否分布式交易处理的XA规范,YES表示支持。
Savepoints参数:表示是否支持保存点,以便事务回滚到保存点,YES 表示支持。

由查询结果可以得出,MySQ1支持的存储引擎有 InnoDB、MRG_MYISAM、MEMORY,PERFORMANCE SCHEMA、ARCHIVE、FEDERATED、CSV、BLACKHOLE、MyISAM,其中 InnoDB为默认存储引擎,该引擎的Support参数值为DEFAULT。

InnoDB存储引擎

InnoDB是 MySOL 数据库的一种存储引擎,InnoDB给MySQL 数据表提供了事务、回归.崩溃修复能力和多版本并发控制的事务安全,支持行锁定和外键等。MySQL的默认存储引擎为InnoDB.InnoDB的主要特性如下:
(1)InnoDB给 MySOL 提供了具有提交,回滚和崩溃恢复能力的事务安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT 语句提供一个类似Oracle的非锁定读。这些功能增加了多用户部署和性能。在SOL查询中,可以自由地将InnoDB类型的表与其他MySQL的表的类型混合起来,甚至在同一个查询中也可以混合。

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

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

(4)InnoDB被用在众多需要高性能的大型数据库站点上。InnoDB 不创建目录,使用 InnoDB时,MySQL将在MySQL数据目录下创建一个名为 ibdatal的10MB 大小的自动扩展数据文件,以及两个名为ib_logfile0和ib_logfile1的5MB大小的日志文件。

MyISAM存储引擎

MyISAM存储引擎是 MySQL中常见的存储引擎,曾是MySQL 的默认存储引擎,MyISAM存储引擎是基于ISAM存储引擎发展起来的,而且增加了很多有用的扩展,如拥有较高的插入、查询速度等,但是它不支持事务,主要特性如下:
(1)大文件(达63位文件长度)在支持大文件的文件系统和操作系统上被支持。

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

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

(4)最大的键长度是1000字节。这也可以通过编译来改变。对于键长度超过250字节的情况,使用一个超过1024字节的键块。

(5) BLOB和 TEXT列可以被索引。

(6)NULL值被允许在索引的列中。

(7)所有数字键值以高字节位先被存储以允许一个更高的索引压缩。

(8)每表一个AUTO INCREMENT 列的内部处理。MyISAM 为 INSERT 和 UPDATE操作自动更新这一列。这使得 AUTO INCREMENT 列更快(至少10%)。在序列顶的值被删除之后就不能再利用。
(9)可以把数据文件和索引文件放在不同目录。

(10)每个字符列可以有不同的字符集。
(11)有VARCHAR的表可以有固定或动态记录长度。

(12)VARCHAR 和 CHAR 列可以多达64KB。
使用MyISAM引擎创建数据库,将产生3个文件。文件的名字以表的名字开始,扩展名指
索引文件的扩展名出文件类型:frm文件存储表定义,数据文件的扩展名为.MYD (MYData)

MEMORY存储引擎

MEMORY存储引擎是 MySQL中的一类特殊的存储引擎,其使用存储在内存中的内容来创建,而且所有数据也放在内存中,这些特性都与 InnoDB存储引擎、MyISAM 存储引擎不同。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)。

存储引擎的选择

不同存储引擎都有各自的特点,适用于不同的需求,为了做出选择,首先需要考虑每一个存储引擎提供了哪些不同的功能。
InnoDB存储引擎:如果要提供提交、回滚和崩溃恢复能力的事务安全(ACID兼容)能力,并要求实现并发控制,InnoDB存储引擎是很好的选择。
MyISAM存储引擎:如果数据表主要用来插入和查询记录,则 MyISAM引擎能提供较高的处理效率,因此MyISAM存储引擎是首选。
MEMORY 存储引擎:如果只是临时存放数据,数据量不大,并且不需要较高的数据安全性,可以选择将数据保存在内存中的MEMORY引擎,MySQL 中使用 MEMORY存储引擎作为临时表存放查询的中间结果。
ARCHIVE存储引擎:如果只有INSERT和 SELECT操作,可以选择ARCHIVE引擎,ARCHIVE

存储引擎支持高并发的插入操作但具大自社不具事冬守全的。ARCHIVE 存储引擎非常适合存储归档数据,如记录日志信息可以使用ARCHIVE引擎。

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

面对以上种种业务需求,华为云提供了针对性的解决方案,从两条路出发,实时保障游戏的平稳运行。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。