开发者社区> 问答> 正文

MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?

MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?

展开
收起
游客ahv54x37wvm7u 2021-12-14 16:16:14 642 0
1 条回答
写回答
取消 提交回答
  • 两种存储引擎的大致区别表现在:

    1.InnoDB支持事务,MyISAM不支持, 这一点是非常之重要。事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了。

    2.MyISAM适合查询以及插入为主的应用。

    3.InnoDB适合频繁修改以及涉及到安全性较高的应用。

    4.InnoDB支持外键,MyISAM不支持。

    5.从MySQL5.5.5以后,InnoDB是默认引擎。

    6.InnoDB不支持FULLTEXT类型的索引。

    7.InnoDB中不保存表的行数,如select count() from table时,InnoDB需要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count()语句包含where条件时MyISAM也需要扫描整个表。

    8.对于自增长的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中可以和其他字段一起建立联合索引。

    9.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的 删除,效率非常慢。MyISAM则会重建表。

    10.InnoDB支持行锁(某些情况下还是锁整表,如 update table set a=1 where user like '%lee%'。

    2021-12-14 16:16:26
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
MySQL表和索引优化实战 立即下载
MySQL 5.7让优化更轻松 立即下载
好的 MySQL 兼容可以做到什么程度 立即下载

相关镜像