首页 > 数据库 > 文库 > 正文

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

2024-09-07 22:12:34
字体:
来源:转载
供稿:网友
         翻译5.7手册InnoDB部分第一篇——InnoDB介绍:

1. InnoDB介绍
       InnoDB是一个高可靠,高性能的多用途数据库存储引擎。在MySQL5.7中InnoDB是默认使用的存储引擎,当然,你可以配置其它存储引擎,比如没有通过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%。

(编辑:武林网)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表