InnoDB与MyISAM等存储引擎对比

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> InnoDB与MyISAM等存储引擎对比

文章原文:

InnoDB存储引擎介绍

InnoDB引擎是Mysql的默认的存储引擎,他有很多自己的特性,下面一一列举。

  • 支持事务,InnoDB存储引擎主要就是为了在线事务处理(OLTP)的应用而设计的。 - 行锁设计,支持外键,非锁定读。 - 支持多版本的并发控制(MVCC)来获得高并发性。 - 提供了插入缓冲、二次写、自适应哈希索引、预读等高性能和高可用的功能。
    上面这些算是 InnoDB 存储引擎的一些特点了,也是它的优势所在,为什么 InnoDB 引擎会使用如此广泛,就是因为它能有很好的性能。

MyISAM储存引擎介绍

  • 不支持事务,它的设计目标是面向在线分析的应用(OLAP)。 - 支持全文索引。 - 表锁设计。 - 它的缓冲池只缓冲索引文件不缓冲数据文件,所以 MyISAM 存储引擎表由 MYD MYI 组成,前者存储数据文件,后者存储索引文件。

    存储引擎之间的对比

这一部分,主要简要的介绍一下各个存储引擎之间的差别,及主要的作用及特点。

特性对比

|特性|MyISAM|InnoDB|BDB|Memory|Archive|NDB
|存储限制|无|64TB|无|有|无|有
|事务||支持|支持|||
|锁级别|表锁|行锁|page|表|行|行
|MVCC(并发控制)||支持|||支持|支持
|全文索引|支持|||||
|集群索引||支持||||
|数据缓存和索引缓存||支持||支持||支持
|数据压缩|支持||||支持|
|批量插入速度|高|低|高|高|很高|高
|集群数据库支持||||||支持
|外键支持||支持||||
|适用场景|不需要事务的操作;插入、更新少,读取频繁;频繁的统计计算。|需要事务的操作;更新数据需要使用行级锁;大数据量读写;大型互联网应用。|类似 InnoDB|数据量不大,需要被频繁的访问,而且数据丢失不会对业务产生比较严重的影响。|存储引擎基本上用于数据归档,作为日志表|集群

存储引擎特性介绍

|存储引擎|主要特点
|BDB|可替代InnoDB的事务引擎,支持COMMIT、ROLLBACK和其他事务特性
|Memory|数据存储在内存中,重启或崩溃,数据消失,使用哈希索引
|Archive|只支持Insert和Select操作,支持索引,非常适合存储归档数据, 目标:高速插入和压缩功能
|NDB|集群存储引擎,数据全部放在内存中,高可用、高性能的集群系统
|Federated|不存放数据,只是指向一台远程MySQL数据库服务器上的表
|Maria|新开发引擎,用于取代MyISAM存储引擎。 支持事务和非事务、缓存、索引文件、行锁、MVCC功能

文章有不当之处,欢迎指正,如果喜欢微信阅读,你也可以关注我的微信公众号 好好学java,获取优质学习资源。

原文地址:https://sihai.blog.csdn.net/article/details/100832158

本人花费半年的时间总结的《Java面试指南》已拿腾讯等大厂offer,已开源在github ,欢迎star!

本文GitHub https://github.com/OUYANGSIHAI/JavaInterview 已收录,这是我花了6个月总结的一线大厂Java面试总结,本人已拿大厂offer,欢迎star

原文链接:blog.ouyangsihai.cn >> InnoDB与MyISAM等存储引擎对比


 上一篇
推荐几个华为、字节跳动、蚂蚁金服的大佬公号 推荐几个华为、字节跳动、蚂蚁金服的大佬公号
是不是觉得公众号关注得太多,没有目的的看文章,没有学到什么知识,时间白白浪费狼。你需要删除些无价值的公众号,在号的数量上做减法,****质量上做加法。接下来给大家推荐一下这段时间一直在阅读的几个优秀公众号。它们每天更新有态度、有温度的原创,
2021-04-04
下一篇 
我,分享我的故事! 我,分享我的故事!
点击上方 **好好学java **,选择 **星标 **公众号 重磅资讯、干货,第一时间送达 这是思否这几天的一个征文活动,有幸邀请回答,就简短的分享了一下我的故事,同时,也有如何学习以及提高能力相关经验的分享。有兴趣可以看一下,当
2021-04-04