目录
1、InnoDB存储引擎
InnoDB 概述
2、MyISAM 存储引擎
3、面试题:两者的区别
1、InnoDB存储引擎
MySQL 5.5时开始作为 默认的存储引擎。
InnoDB 是 MySQL 的默认事务型存储引擎,也是最重要,使用最广泛的存储引擎。它被设计用来处理大量短期的事务,短期事务大部分都是正常提交的,很少回滚。InnoDB 的性能和自动崩溃恢复特性,使得它在非事务型存储的需求中也很流行。
InnoDB 概述
InnoDB 的数据存储是在表空间中,表空间是由 InnoDB 管理的一个黑盒子,由一系列的数据文件组成。
InnoDB 采用 MVCC 来支持高并发,并且实现了四个标准的隔离级别,其默认级别是:可重复读(REPEATABLE READ),并且通过间隙锁策略防止幻读的出现。间隙锁使得 InnoDB 不仅仅锁定查询涉及的行,还会对索引中的间隙进行锁定,以防止幻影行插入。
InnoDB 表是基于聚簇索引建立的。
聚簇索引对主键索引查询有很高的性能,不过非主键索引中间必须包括主键列,所以主键列很大其他索引也会很大。
2、MyISAM 存储引擎
MyISAM 是 MySQL 5.1之前版本的默认存储引擎。MyISAM 提供了大量的特性,包括全文索引、压缩、空间函数等,但MyISAM 不支持事务和行级锁,奔溃后无法恢复。
3、面试题:两者的区别
区别 | InnoDB | MyISAM | |
1 | 事务 | 支持 | 不支持 |
2 | 行级锁 | 支持 | 不支持,支持表级锁 |
3 | MVCC | 支持 | 不支持 |
4 | 外键 | 支持 | 不支持 |
5 | 全文索引 | 不支持 | 支持 |
6 | 空间函数GIS | 不支持 | 支持 |
7 | AUTO_INCREMENT | InnoDB中必须包含AUTO_INCREMENT类型字段的索引 | MyISAM中可以使AUTO_INCREMENT类型字段建立联合索引 |
8 | 表压缩 | 表格很难被压缩 | 表格可以被压缩 |
9 | 跨平台拷贝 | 跨平台可直接拷贝使用 | 跨平台很难直接拷贝 |
10 | count(*) 行数 | 不保存表的具体行数,扫描表来计算有多少行 | 保存表的具体行数,不带where时,直接返回保存的行数 |
11 | 清空整个表 | InnoDB是一行一行的删除,效率非常慢 | DELETE 表时,先drop表,然后重建表 |
12 | 索引和数据存储 | InnoDB 把数据和索引存放在表空间里面 | MyISAM 表被存放在三个文件 。frm 文件存放表格定义。 数据文件是MYD (MYData) 。 索引文件是MYI (MYIndex)引伸 |
13 | 聚簇索引区别 |