MySQL数据引擎,12缸就是猛!
12缸的帕萨特惹不起,12缸的高尔夫堪比法拉利!
网上写MySQL的文章比较多,但对数据库引擎介绍的文章比较少,无论是汽车、飞机还是MySQL,引擎都堪称灵魂,今天就简单说说MySQL的两大数据引擎MyISAM和InnoDB。
(2)MyISAM强调的是性能,每次查询具有原子性,是不提供事务支持;
(3)MyISAM只支持表级锁;
(4)MyISAM索引和数据分离,天生非聚簇索引,最多有一个unique的性质,这样在内存里可以缓存更多的索引,对查询的性能会更好,适用于那种少量的插入,大量查询的场景;
MyISAM适用于什么场景?
基于MySQL,搭建J2EE的在线报表查询Web系统,是最适合MyISAM存储引擎的,因为并不需要事务支持,就是在最初的时候一次性批量导入大量数据,然后基于这些属于开始查询
(1)InnoDB支持事务,它的AUTO_COMMIT默认是打开的。意味着每条SQL语句都会被默认封装成一个事务,自动提交;
(2)InnoDB支持行级锁,这是它的最大特色。行锁大幅度提高了多用户并发操作的性能;
(3)InnoDB引擎表的所有内容都保存在同一个数据文件中,索引和数据并不分开;
(4)InnoDB需要更多的内存和存储,它会在主内存中建立其专用的缓冲池用于高速缓冲数据和索引;