MySQL数据引擎InnoDB和MyISAM,12缸就是猛!

开足码力,码动人生,微信搜索【 程序员大帝 】,关注这个一言不合就开车的的代码界老司机
本文 GitHub上已经收录 https://github.com/BeKingCoding/JavaKing , 一线大厂面试核心知识点、我的联系方式和技术交流群,欢迎Star和完善

网上写MySQL的文章比较多,但对数据库引擎介绍的文章比较少,无论是汽车、飞机还是MySQL,引擎都堪称灵魂,今天就简单说说MySQL的两大数据引擎MyISAM和InnoDB。

画外音:五分钟,几幅图,秒懂。

首先我们来看看MySQL的整体架构是怎么样的?

在这里插入图片描述

MySQL整体分为三层:
(1)客户端,提供统一的接口,让各种编程语言去实现connector;
(2)MySQL服务,内部包含各种组件,实现各种功能;
(3)文件系统,数据存储与日志;

其中,MySQL服务中,可以以插件的形式,实现各种存储引擎。

在各种存储引擎中,MyISAM和InnoDB是使用范围最广的。

MyISAM是怎么样的?

(1)MyISAM是MySQL 5.5版本之前的默认数据库引擎;
(2)MyISAM强调的是性能,每次查询具有原子性,是不提供事务支持;

(3)MyISAM只支持表级锁;

(4)MyISAM索引和数据分离,天生非聚簇索引,最多有一个unique的性质,这样在内存里可以缓存更多的索引,对查询的性能会更好,适用于那种少量的插入,大量查询的场景;

MyISAM适用于什么场景?

基于MySQL,搭建J2EE的在线报表查询Web系统,是最适合MyISAM存储引擎的,因为并不需要事务支持,就是在最初的时候一次性批量导入大量数据,然后基于这些属于开始查询

画外音:MyISAM适合读要求的高性能查询

InnoDB是怎么样的?

(1)InnoDB支持事务,它的AUTO_COMMIT默认是打开的。意味着每条SQL语句都会被默认封装成一个事务,自动提交;

(2)InnoDB支持行级锁,这是它的最大特色。行锁大幅度提高了多用户并发操作的性能;

(3)InnoDB引擎表的所有内容都保存在同一个数据文件中,索引和数据并不分开;

(4)InnoDB需要更多的内存和存储,它会在主内存中建立其专用的缓冲池用于高速缓冲数据和索引;

画外音:事务,行锁,聚集索引,MVCC…众多特性让InnoDB备受青睐。

如果大家对事务、聚餐/非聚餐索引、MVCC等概念还不是很了解的话,后续我会带来更多相关文章


Offer收割机》系列持续更新,也会定期分享互联网常用技术栈相关的文章,GitHub 上已经收录 https://github.com/BeKingCoding/JavaKing ,讲解一线大厂面试要求的核心知识点、并有对标阿里P7级别的成长体系脑图,欢迎加入技术交流群,我们一起有点东西。


在这里插入图片描述


我是一言不合就开车的代码界老司机无忌。创作不易,各位的支持和认可,就是我创作的最大动力,我们下篇文章见!
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值