3.5 数据库存储引擎

MySQL中的存储引擎是指表的类型,数据库的存储引擎决定了表在计算机中的存储方式。不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能,使用不同的存储引擎,还可以获得特定的功能,MySQL的核心就是存储引擎。

3.5.1 MySQL存储引擎简介

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

【实例12】使用SHOW ENGINES语句查看系统所支持的引擎类型,输入如下语句:

结果中主要参数介绍如下。

  • Engine参数:指存储引擎的名称。
  • Support参数:说明MySQL是否支持该类引擎。
  • Comment参数:指对该引擎的评论。
  • Transactions参数:表示是否支持事务处理,YES表示可以使用,NO表示不能使用。
  • XA参数:表示是否分布式交易处理的XA规范,YES表示支持。
  • Savepoints参数:表示是否支持保存点,以便事务回滚到保存点,YES表示支持。

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

MySQL中另一个SHOW语句也可以显示支持的存储引擎的信息。

【实例13】使用SHOW语句查询MySQL支持的存储引擎,输入如下语句:

    mysql> SHOW VARIABLES LIKE 'have%';

按Enter键,即可返回查询结果,如图3-16所示。从查询结果中可以得出,第一列Variable_name表示存储引擎的名称,第二列Value表示MySQL的支持情况。YES表示支持,NO表示不支持;DISABLED表示支持但还没有开启。

提示:创建数据表时,如果没有指定存储引擎,表的存储引擎将为默认的存储引擎。本书中MySQL的默认存储引擎为InnoDB。

图3-16 存储引擎查询结果

3.5.2 InnoDB存储引擎

InnoDB是MySQL数据库的一种存储引擎,InnoDB给MySQL数据表提供了事务、回归、崩溃修复能力和多版本并发控制的事务安全,支持行锁定和外键等。MySQL的默认存储引擎为InnoDB。InnoDB的主要特性如下:

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

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

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

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

3.5.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),索引文件的扩展名是.MYI (MYIndex)。

3.5.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)。

3.5.5 存储引擎的选择

不同存储引擎都有各自的特点,适用于不同的需求,为了做出选择,首先需要考虑每一个存储引擎提供了哪些不同的功能。表3-1是常用存储引擎的功能比较。

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

MyISAM存储引擎:如果数据表主要用来插入和查询记录,则MyISAM引擎能提供较高的处理效率,因此MyISAM存储引擎是首选。

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

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

表3-1 存储引擎比较

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