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

目录

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、面试题:两者的区别

 区别InnoDBMyISAM
1事务支持不支持
2行级锁支持不支持,支持表级锁
3MVCC支持不支持
4外键支持不支持
5全文索引不支持支持
6空间函数GIS不支持支持
7AUTO_INCREMENTInnoDB中必须包含AUTO_INCREMENT类型字段的索引MyISAM中可以使AUTO_INCREMENT类型字段建立联合索引
8表压缩表格很难被压缩表格可以被压缩
9跨平台拷贝跨平台可直接拷贝使用跨平台很难直接拷贝
10count(*) 行数不保存表的具体行数,扫描表来计算有多少行保存表的具体行数,不带where时,直接返回保存的行数
11清空整个表InnoDB是一行一行的删除,效率非常慢DELETE 表时,先drop表,然后重建表
12索引和数据存储InnoDB 把数据和索引存放在表空间里面MyISAM 表被存放在三个文件 。frm 文件存放表格定义。 数据文件是MYD (MYData) 。 索引文件是MYI (MYIndex)引伸
13聚簇索引区别  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值