MySQL数据引擎,12缸就是猛

网上写MySQL的文章比较多 , 但对数据库引擎介绍的文章比较少 , 无论是汽车、飞机还是MySQL , 引擎都堪称灵魂 , 今天就简单说说MySQL的两大数据引擎MyISAM和InnoDB 。
首先我们来看看MySQL的整体架构是怎么样的?

MySQL数据引擎,12缸就是猛

文章插图
 
MySQL整体分为三层:
(1)客户端 , 提供统一的接口 , 让各种编程语言去实现connector;
(2)MySQL服务 , 内部包含各种组件 , 实现各种功能;
(3)文件系统 , 数据存储与日志;
其中 , MySQL服务中 , 可以以插件的形式 , 实现各种存储引擎 。
在各种存储引擎中 , MyISAM和InnoDB是使用范围最广的 。
MyISAM是怎么样的?
(1)MyISAM是MySQL 5.5版本之前的默认数据库引擎;
(2)MyISAM强调的是性能 , 每次查询具有原子性 , 是不提供事务支持;
【MySQL数据引擎,12缸就是猛】(3)MyISAM只支持表级锁;
(4)MyISAM索引和数据分离 , 天生非聚簇索引 , 最多有一个unique的性质 , 这样在内存里可以缓存更多的索引 , 对查询的性能会更好 , 适用于那种少量的插入 , 大量查询的场景;
MyISAM适用于什么场景?
基于MySQL , 搭建J2EE的在线报表查询Web系统 , 是最适合MyISAM存储引擎的 , 因为并不需要事务支持 , 就是在最初的时候一次性批量导入大量数据 , 然后基于这些属于开始查询
MySQL数据引擎,12缸就是猛

文章插图
 
InnoDB是怎么样的?
(1)InnoDB支持事务 , 它的AUTO_COMMIT默认是打开的 。意味着每条SQL语句都会被默认封装成一个事务 , 自动提交;
(2)InnoDB支持行级锁 , 这是它的最大特色 。行锁大幅度提高了多用户并发操作的性能;
(3)InnoDB引擎表的所有内容都保存在同一个数据文件中 , 索引和数据并不分开;
(4)InnoDB需要更多的内存和存储 , 它会在主内存中建立其专用的缓冲池用于高速缓冲数据和索引;
如果大家对事务、聚餐/非聚餐索引、MVCC等概念还不是很了解的话 , 后续我会带来更多相关文章
知其然 , 知其所以然 , 希望大家有收获 。
欢迎关注同名公众号【程序员大帝】 , 更多原创精品内容




    推荐阅读