几种数据库存储引擎比较
1.Mysql 存储引擎简介
存储引擎的概念是 MySQL 的特点,而且是一种插入式的存储引擎概念。这决定了 MySQL 数据库中的表可以用不同的方式存倍。用户可以根据自己的需求,选择不同的存储方式、是否进行驶入处理等。
使用 SHOW ENGINES 语句杳看系统所支持的引擎类型
结果中主要参数介绍如下。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。
2. 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 大小的日志文件。
3. 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)
4. 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)。
5. 存储引擎的选择
不同存储引擎都有各自的特点,适用于不同的需求,为了做出选择,首先需要考虑每一个存储引擎提供了哪些不同的功能。表 3-1 是常用存储引擎的功能比较。InnoDB 存储引擎:如果要提供提交、回滚和崩溃恢复能力的事务安全(ACID 兼容)能力,并要求实现并发控制,InnoDB 存储引擎是很好的选择。MyISAM 存储引擎:如果数据表主要用来插入和查询记录,则 MyISAM 引擎能提供较高的处理效率,因此 MyISAM 存储引擎是首选。MEMORY 存储引擎:如果只是临时存放数据,数据量不大,并且不需要较高的数据安全性,可以选择将数据保存在内存中的 MEMORY 引擎,MySQL 中使用 MEMORY 存储引擎作为临时表存放查询的中间结果。ARCHIVE 存储引擎:如果只有 INSERT 和 SELECT 操作,可以选择 ARCHIVE 引擎,ARCHIVE
存储引擎支持高并发的插入操作但具大自社不具事冬守全的。ARCHIVE 存储引擎非常适合存储归档数据,如记录日志信息可以使用 ARCHIVE 引擎。
总之,使用哪一种引擎要根据需要灵活选择,一个数据库中的多个表可以使用不同的引擎以满足各种性能和实际需求,使用合适的存储引擎,将会对整个数据库的性能有帮助。
版权声明: 本文为 InfoQ 作者【乌龟哥哥】的原创文章。
原文链接:【http://xie.infoq.cn/article/eec74207972ec670c0b941ec7】。文章转载请联系作者。
评论 (2 条评论)