当前位置: 代码迷 >> 综合 >> MySQL的存储引擎InnoDB 和 MyISAM 区别(面试题)
  详细解决方案

MySQL的存储引擎InnoDB 和 MyISAM 区别(面试题)

热度:97   发布时间:2023-12-21 19:21:21.0

目录

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 聚簇索引区别    

 

  相关解决方案