MySQL 数据库区别于其他数据库的最重要的一个特别就是其插件式的表存储引擎。MySQL 存储引擎提供了一系列标准的管理和服务支持,每个存储引擎是底层物理结构的实现。

需要注意的是,存储引擎是基于表的,而不是数据库。

InnoDB

InnoDB 存储引擎支持事务,其特点是行锁设计、支持外键、并支持类似于 Oracle 的非锁定读,即默认读取操作不会产生锁。

从 MySQL 数据库 5.5.8 开始,InnoDB 存储引擎是默认的存储引擎。

InnoDB 通过使用多版本并发控制(MVCC)来获得高并发性,并且实现了 4 种隔离级别,默认是 REPEATABLE (可重复读)级别。同时,使用一种被称为 next-key-locking 的策略来避免幻读(phantom)现象的产生。除此之外,InnoDB 存储引擎还提供了插入缓存(insert buffer)、二次写(double write)、自适应哈希索引(adaptive hash index)、预读(read ahead)等高性能和高可用的功能。

对于表中数据的存储,InnoDB 存储引擎采用了聚集的方式,因此每张表的存储都是按主键的顺序进行存放。如果没有显式地在表定义时指定主键,InnoDB 存储引擎会为每一行生成一个 6 字节的 ROWID,并以为作为主键。

MyISAM

MyISAM 存储引擎不支持事务、表锁设计,支持全文索引。在 MySQL 5.5.8 版本之前,MyISAM 是默认的存储引擎。

此外,MyISAM 存储引擎的另一个与众不同的地方是它的缓冲池只缓存索引文件,而不缓冲数据文件,这点和大多数的数据库都非常不同。

MyISAM 存储引擎表由 MYD 和 MYI 组成,MYI 用来存放数据文件,MYI 用来存放索引文件。


代码笔耕
0 声望1 粉丝