MySQL数据库中 InnoDB 与 MyISAM的区别及其应用场景

InnoDB 与 MyISAM 都是MySQL数据库的引擎。

1.他们的区别分为五点:

(1).事务处理:
MyISAM是非事务安全型的,而InnoDB是事务安全型的(支持事务处理等)
(2).锁机制不同:
MyISAM是表锁,InnoDB是行级锁。
(3).增删改查操作:
MyISAM:如果执行大量的查询操作,MyISAM是更好的选择
InnoDB:如果你的数据执行大量的插入/更新,出于性能方面的考虑,应该使用InnoDB表
(4).查询表的行数不用:
MyISAM: 执行select count() from table语句时 MyISAM只需要简单的查询出保存好的行数,当count()语句包含 where条件时,两种表的操作是一样的。
InnoDB: InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行
(5).外键
MyISAM不支持外键
mysiam表不支持外键,而InnoDB支持

2. 为什么MyISAM会比Innodb 的查询速度快。

NNODB在做SELECT的时候,要维护的东西比MYISAM引擎多很多;
(1)数据块,INNODB要缓存,MYISAM只缓存索引块, 这中间还有换进换出的减少;
(2)innodb寻址要映射到块,再到行,MYISAM 记录的直接是文件的OFFSET,定位比INNODB要快
(3)INNODB还需要维护MVCC一致;虽然你的场景没有,但他还是需要去检查和维护MVCC ( Multi-Version Concurrency Control )多版本并发控制

3.应用场景

MyISAM适合:(1)做很多count 的计算;(2)插入不频繁,查询非常频繁;(3)没有事务。
InnoDB适合:(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都相当的频繁,并且行锁定的机会比较大的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值