MySQL存储引擎MyISAM与InnoDB的区别比较

10 篇文章 0 订阅
9 篇文章 0 订阅

使用MySQL当然会接触到MySQL的存储引擎,在新建数据库和新建数据表的时候都会看到。

MySQL的默认引擎5.7以前是MyISAM,5.7以后是InnoDB。建议使用InnoDB。

至于到底用哪种存储引擎比较好?这个问题没有定论,需要根据你的需求和环境来衡量。所以对这两种引擎的概念、原理、异同和各自的优劣点有了详细的了解之后,再根据自己的情况选择起来就容易多了。

MyISAMInnoDB
存储结构每张表被存放在三个文件:
1.frm - 表格定义 2.MYD(MYData) - 数据文件
3.MYI(MYIndex) - 索引文件
所有的表都保存在同一个数据文件中
(也可能是多个文件,或者是独立的表空间文件),
InnoDB表的大小只受限制于操作系统文件的大小,一般为2GB
存储空间MyISAM可被压缩,存储空间较小InnoDB的表需要更多的内存和存储,
它会在主内存中建立其专用的缓冲池,用于高速缓冲数据和索引
可移植性、备份及恢复由于MyISAM的数据是以文件的形式存储,
所以在跨平台的数据转移中会很方便。
在备份和恢复时可单独针对某个表进行操作
免费的方案可以时拷贝数据文件、备份binlog,或者用mysqldump,
在数据量达到几十G的时候就相对痛苦了
事务安全不支持,每次查询具有原子性支持具有事务、回滚和崩溃修复能力(crash recovery
capabilities)的事务安全(transaction-safe(ACID compliant))型表
AUTO_INCREMENTMySIAM表可以和其他字段一起建立联合索引InnoDB中必须包含只有该字段的索引
SELECTMyISAM更优秀
INSERTInnoDB更优秀
UPDATEInnoDB更优秀
DELETEInnoDB更优秀,它会回重新建立表,而是一行一行的删除
COUNT without WHEREMyISAM更优秀,因为MyISAM保存了表的具体行数InnoDB没有保存表的具体行数,需要逐行扫描统计,就很慢了
COUNT with WHERE一样一样,InnoDB也会锁表
只支持表锁支持表锁、行锁。行锁大幅提高了多用户并发操作的性能。
但是InnoDB的行锁,只是在WHERE的主键是有效的,
非主键的WHERE都会锁全表
外键不支持支持
FULLTEXT全文索引支持5.6+支持,可以通过使用Sphinx从InnoDB中获得全文索引,会慢一点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值