InnoDB 和 MyISAM 的区别

  • InnoDB 支持外键和事务,MyISAM 不支持
  • InnoDB 支持行锁和表锁,MyISAM 只支持表锁
  • InnoDB 有重启后的崩溃恢复功能 (基于事务)
  • MyISAM 只缓存索引,不缓存真实数据;InnoDB 不仅缓存索引还缓存真实数据,对内存要求较高,且内存大小对性能有决定性的影响
  • 数据量较小,且操作多为插入和查询时,MyISAM 性能高一些
  • MyISAM 针对数据统计有额外的变量存储,故 count(*) 的查询效率很高
  • 数据文件结构
    • InnoDB:表名.frm (存储表结构,8.0 时被合并到 .ibd 中)、表名.ibd (存储数据和索引)
    • MyISAM:表名.frm (存储表结构)、表名.myd (存储数据)、表名.myi (存储索引)

MySQL 5.5 开始默认存储引擎为 InnoDB (之前为 MyISAM)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值