翻译5.7手册InnoDB部分第一篇——InnoDB介绍


1. InnoDB介绍

InnoDB是一个高可靠,高性能的多用途数据库存储引擎。在MySQL5.7InnoDB是默认使用的存储引擎,当然,你可以配置其它存储引擎,比如没有通过ENGINE设置为InnoDB的建表语句。

InnoDB的关键特性

列举以下重要几点:

  • DML操作在ACID模式下执行(插入,更新,删除操作,要注意的是查询操作有时候也可能认为是DML操作,如select * from table for update,也就是关于事务的提交,回滚,故障恢复。

  • 行级锁和类似Oracle的非锁定读以及多用户的支持。

  • 聚集索引,InnoDB会根据表的主键在数据存储的时候对数据进行排序以减少通过主键查询时的I/O。每一个InnoDB表的主键就是一个聚集索引

  • 在保证数据完整性方面,InnoDB支持外键,有外键存在时,数据在插入,更新和删除的时候都有外键约束。

InnoDB特性

Storage limits

存储限制

64TB

Transactions

事务

Yes

Locking granularity

锁粒度

Row

MVCC

多版本并发控制

Yes

Geospatial data type support

地理坐标数据类型支持

Yes

Geospatial indexing support

坐标索引支持

Yes[a]

B-tree indexes

B-tree 索引

Yes

T-tree indexes

T-tree 索引

No

Hash indexes

哈希索引

No[b]

Full-text search indexes

全文索引

Yes[c]

Clustered indexes

聚集索引

Yes

Data caches

缓存

Yes

Index caches

索引缓存

Yes

Compressed data

压缩功能

Yes[d]

Encrypted data[e]

加密功能

Yes

Cluster database support

集群支持

No

Replication support[f]

复制支持

Yes

Foreign key support

外键支持

Yes

Backup / point-in-time recovery[g]

时间点恢复

Yes

Query cache support

查询缓存支持

Yes

Update statistics for data dictionary

更新静态字典数据

Yes

一些特性说明:

[a] MySQL5.7.5以及更高的版本中InnoDB 支持地理位置。

[b] InnoDB 在自适应哈希索引内部使用哈希索引。

[c] MySQL 5.6.4 以及更高的版本中InnoDB 支持全文索。

[d] 表压缩功能需要Barracuda 的文件格式

[e] 通过加密函数实现。

[f] 支持,但不是在引擎级别实现。

[g] 支持,但不是在引擎级别实现。.

 

各种存储引擎的对比将在后面的章节中详细列出。

1.1     为什么要选择InnoDB

选择InnoDB的理由如下:

  • 如果你的服务器由于硬件或软件的问题而崩溃,你不用考虑数据库当时发生的事情,也不需要你在数据库重新启动后做任何特殊处理。InnoDB的故障恢复机制会自动帮你完成所有在故障发生前的提交,另外,对没有提交的动作不做任何操作。

  • InnoDB存储引擎对于访问的数据在内存中持有一个缓存表数据和索引的缓存池,用户的一些查询可以从内存中的缓存池中直接返回数据。这种缓存方式适用于很多提高处理速度的场景。在一台专用的数据库服务器上,InnoDB缓存池的内存占用通常都高于总内存的80%