mysql myisam 详解_【MySQL】MyISAM和InnoDB存储引擎区别详解

MyISAM

主键索引(引擎的索引文件和数据文件是分离的)

be701ce7163676ec472b5aff2d6ac4ba.png

非主键索引(索引结构跟上面的主键索引的结构是相同的。)

5a3e78824f50e3900ebf109e649bbd6b.png

InnoDB:

主键索引(索引结构是在同一个树节点中同时存放索引和数据)

221ca4373c922707b9e20705d93e9057.png

非主键索引(在最底层的叶子结点有两行数据,第一行的字符串是辅助索引,按照ASCII码进行排序,第二行的整数是主键的值)

5c5fc8da4337ad1579ca764383c3a7f0.png

InnoDB索引实现(聚集)

表数据文件本身就是按B+Tree组织的一个索引结构文件

聚集索引- 叶子节点包含了完整的数据记录

为什么InnoDB表必须有主键,并且推荐使用整型的自增主键?

为什么非主键索引结果叶子节点存储的是主键值?(一致性和节省存储空间)

总结一下: InnoDB和MyISAM的区别:

1》InnoDB 支持事务,MyISAM 不支持事务。这是 MySQL 将默认存储引擎从 MyISAM 变成 InnoDB 的重要原因之一;

2》InnoDB 支持外键,而MyISAM 不支持外键。对一个包含外键的 InnoDB 表转为 MYISAM 会失败;

3》InnoDB 是聚集索引,MyISAM 是非聚集索引。聚簇索引的文件存放在主键索引的叶子节点上,因此 InnoDB 必须要有主键,通过主键索引效率很高。但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。因此,主键不应该过大,因为主键太大,其他索引也都会很大。而 MyISAM 是非聚集索引,数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。

4》InnoDB 不保存表的具体行数,执行 select count(*) from table 时需要全表扫描。而MyISAM 用一个变量保存了整个表的行数,执行上述语句时只需要读出该变量即可,速度很快;

5》InnoDB 最小的锁粒度是行锁,MyISAM 最小的锁粒度是表锁。一个更新语句会锁住整张表,导致其他查询和更新都会被阻塞,因此并发访问受限。这也是 MySQL 将默认存储引擎从 MyISAM 变成 InnoDB 的重要原因之一;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值