美文网首页
MySQL MyISAM与InnoDB区别

MySQL MyISAM与InnoDB区别

作者: 沁心轩墨 | 来源:发表于2017-12-26 12:53 被阅读0次

    1.MyISAM

    MyISAM是mysql5.1及之前版本的默认引擎,很久未被更新。

    使用表级锁, 如果数据量大,一个插入操作锁定表后,其他请求都将阻塞。

    支持全文索引

    支持查询缓存

    保存表的总行数,使用count(*) 并且无where子句的时候可以很快返回结果,但是实际使用时基本不会无where子句

    简要:不支持事务安全

    没有事务日志和分类,因此它只将数据写入Linux文件缓存并希望能最终写入磁盘。如果系统在这个过程中崩溃或者丢失一些数据,MyISAM表会经常出现无法启动或者警告你需要修复表;它恢复数据的方法有限并且经常会丢失数据。另外,MyISAM也很难正确的备份,备份的时候通常需要锁住整个系统的数据,这就意味着每天网站都要宕机或者无法使用一段时间。

    MyISAM表允许在定期列中进行全文检索,而InnoDB不支持

    2.InnoDB

    支持事务

    支持行级锁和表级锁,能支持更多的并发量

    mysql5.6版本开始支持 全文索引

    Innodb会对每个表设置一个事务计数器,里面存储当前最大的事务ID.当一个事务提交时,InnoDB会使用MVCC中系统事务ID最大的事务ID跟新当前表的计数器.只有比这个最大ID大的事务能使用查询缓存,其他比这个ID小的事务则不能使用查询缓存.另外,在InnoDB中,所有有加锁操作的事务都不使用任何查询缓存

    简要:支持事务安全

    事务日志记录真正的数据库事务,但更重要的是数据崩溃恢复和回滚。基于 InooDB方式的IO,能给予更安全数据保护和更好性能表现

    相关文章

      网友评论

          本文标题:MySQL MyISAM与InnoDB区别

          本文链接:https://www.haomeiwen.com/subject/zdvjkxtx.html