目录
MySQL体系结构
存储引擎简介
InnoDB
介绍
特点
文件
MyISAM
介绍
特点
文件
Memory
介绍
特点
文件
选择
小结
MySQL体系结构
MySQL的系统体系结构一般来说分为一下几层:
- 连接层
- 服务层
- 引擎层
- 储存层
存储引擎简介
存储引擎是储存数据,建立索引,更新/查询数据的实现方式。引擎没有好坏之分,不同的场景应该选择合适的引擎。引擎是基于表的,而不是基于库的,所以也被称为表类型。
在创建表时,指定储存引擎类型:
create table 表名 (
字段1,字段类型 [ 注释 ] ,
字段2,字段类型 [ 注释 ]
)Engine = 储存类型 [ 注释 ] ;
查看当前数据库支持的储存引擎:
show engines;
-
InnoDB
介绍
InnoDB是一种高可靠性和高性能性的储存引擎,自从MySQL 5.5之后,InnoDB就是MySQL的默认储存引擎。
特点
- DML操作遵循ACID原则
- 行级锁,提高并发性能
- 支持外键约束,提高数据的一致性和完整性
文件
xxx.ibd,innnoDB的每张表都有一个对应的表文件,储存表结构,数据和索引。
逻辑储存结构
MyISAM和Memory
-
MyISAM
介绍
是早期MySQL的默认储存引擎
特点
支持表锁,不支持行锁
访问速度更快
文件
xxx.sdi 储存表结构信息
xxx.MYD 储存数据
xxx.MYI 储存索引
-
Memory
介绍
Memory时储存在内存中的,由于受到硬件影响或者是断电等问题,所以一般储存临时信息、临时表
特点
内存储存
hash索引(默认)
- 也是表锁
文件
xxx.sdi 储存表结构信息
选择
针对应用系统的选择合适的储存引擎,当然也可以根据实际系统的情况,自由的对储存引擎进行组合
- InnoDB:是MySQL的默认储存引擎,支持事务,外键。如果对于事物的完整性,并发事务条件下希望保证数据的一致性,除了查询插入操作还有大量删除更新操作,那么InnoDB是最好的选择。
- MyISAM:一般是大量查询插入操作,少量删除更新操作,并且对于事务的完整性、并发性并没有许多要求,那么这个将会是最好的选择。
- Memor:储存在内存中,访问速度快,通常用于临时表及缓存。缺点是有表的大小限制,不能存储大量的数据,无法保证数据的安全性。