MySql MyISAM和InnoDB的区别

本文对比了Mysql中两种存储引擎InnoDB与MyISAM的特点:MyISAM适用于读多写少场景,提供良好性能平衡;InnoDB支持事务处理及高并发读写,适合对事务有高要求的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网站的Mysql存储引擎一直为InnoDB,而常见的还有MyISAM,Memory等,看了《高性能Mysql》这本书后,对比了下他们之间的区别,简单总结一下:
MyISAM默认为Mysql的存储引擎,在性能和可用特征之间,MyISAM提供了良好的平衡,但MyISAM不支持事务和行级锁,他对整张表进行加锁,适用于select,insert,高负载的场合,在读写并重的场合并不适用,系统开销比较小。个人认为一次写入频繁读取的情况比较适用。
InnoDB,支持MVCC的行级锁,InnoDB表的行锁也不是绝对的,假如在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,把数据和内存缓存在缓冲区池里,会自动构建哈希索引以加快行读取;支持事务,不支持全文检索,适用于高并发读写,当然系统开销也比较大。个人认为对事务要求高,有并发性要求高的,有大量更新和删除的情况比较适用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值