当前位置: 首页 > 工具软件 > MyISAM > 使用案例 >

MyISAM 与 InnoDB 的区别是什么?

百里金林
2023-12-01
  • InnoDB支持事务,MyISAM不支持
  • InnoDB 支持外键,而 MyISAM 不支持
  • 「InnoDB是聚集索引」,使用B+Tree作为索引结构,数据文件是和索引绑在一起的,必须要有主键。「MyISAM是非聚集索引」,也是使用B+Tree作为索引结构,索引和数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。
  • 「InnoDB 不保存表的具体行数」「MyISAM 用一个变量保存了整个表的行数」
  • Innodb 有 「redolog」 日志文件,MyISAM 没有
  • 「Innodb存储文件有frm、ibd,而Myisam是frm、MYD、MYI」
    • Innodb:frm是表定义文件,ibd是数据文件
    • Myisam:frm是表定义文件,myd是数据文件,myi是索引文件
  • 「InnoDB 支持表、行锁,而 MyISAM 支持表级锁」
  • 「InnoDB 必须有唯一索引(主键)」,如果没有指定的话 InnoDB 会自己生成一个隐藏列Row_id来充当默认主键,「MyISAM 可以没有」
  • MyISAM只缓存索引,不缓存真实数据,InnoDB不仅缓存索引还要缓存真实数据,对内存要求较高,而且内存大小对性能有决定性的影响
 类似资料: