InnoDB与MyISAM的区别(高性能MySQL笔记)
1、InnoDB支持事务,MyISAM不支持,也就是说MyISAM不支持事务回滚操作,这个功能可能是致命的
2、InnoDB支持行锁,MyISAM只支持表锁,不过InnoDB的行锁是建立在索引之上的,也就是说如果索引未命中,那么此次操作还是会降级到表锁。如uid为索引
update t_user set age=10 where uid=1; 命中索引,行锁。
update t_user set age=10 where uid != 1; 未命中索引,表锁。
3、InnoDB表是基于聚簇索引建立的,采用B+树,MyISAM是基于非聚簇索引,索引数据结构也是B+树
聚簇索引:它并不是一种单独的索引类型,而是一种数据存储方式。聚簇索引是依托主键而建立的,这种存储方式将索引值与数据行全部存储到同一个结构中。
如果没有主键,InnoDB会选择一个唯一的非空索引代替,如果没有符合条件的索引,InnoDB会隐式的创建一个主键来作为聚簇索引。InnoDB中,其非聚簇索引,又叫辅助索引或者二级索引,他们是将数据行地址(这里更正一下,二级索引中存放的并不是指向行的指针,而是行的主键值!)存到B+树的叶子结点中,也就是说,想通过二级索引查找行数据,存储引擎需要先找到二级索引的叶子结点对应的主键值,然后根据这个值去聚簇索引中查找到相应的数据行。这里做了重复的工作,因此至少做两次B+tree查找(至少,是因为可能有的数据更新后无法存储在原来的位置,这会导致表中出现行的碎片化或者在原位置留下一个指向新位置的指针,因此一次非聚簇索引未必能找到目的主键值)。对于InnoDB来说,自适应哈希索引能够减少这样的重复工作。
因此,聚簇索引对于IO密集型的系统来说至关重要,可以大大提高其性能。但如果系统将数据全部存放在内存中,聚簇索引便没什么优势了。但是,聚簇索引也有一定的弊端,比如更新局促索引列的代价太高,整行数据都得跟着索引移到新的位置,还有页分裂问题等。
对于MyISAM存储引擎,包含以下三种格式的文件:
.frm 是描述表结构的文件
.MYD 是表的数据文件
.MYI 是表数据文件中任何索引的数据树
对于InnoDB,索引和数据都在同一个文件内,.IDB
4、InnoDB是不保存表的具体行数,执行select count(*) from table时需要全表扫描。而MyISAM用一个变量保存了整个表的行数,执行上述语句时只需要读出该变量即可,速度很快
5、InnoDB版本5.7之后才开始支持全文索引,而MyISAM一直支持全文索引
6、MyISAM是支持压缩的,压缩后的表传输、查询速率都大大提高,不过压缩状态下的表是不可以修改的,只有解压后才可修改
7、InnoDB支持外键而MyISAM不支持,也就是说,如果将一个表由InnoDB转成MyISAM然后再转回来,外键会消失
8、InnoDB表必须有主键(用户没有指定的话会自己找或生成一个隐式主键),而Myisam可以没有
那么二者如何选择呢?
- 如果需要事务和事务回滚,InnoDB!
- 如果读远多于写,MyISAM!
- 如果你还是没主意,那就InnoDB吧,毕竟它是目前主推(默认)的内存引擎
最后,这里提一下InnoDB引擎的四大特性(想要深入研究的同学可以看这位博主的链接):插入缓冲(insert buffer),二次写(double write),自适应哈希索引(ahi),预读(read ahead)
InnoDB与MyISAM的区别(高性能MySQL笔记)的更多相关文章
- MySQL之innodb和myisam的区别
innodb和myisam的区别: MyISAM在磁盘上存储成三个文件.第一个文件的名字以表的名字开始,扩展名指出文件类型, .frm文件存储表定义, 数据文件的扩展名为.MYD, 索引文件的扩展名是 ...
- InnoDB和MyISAM的区别与选择
MyISAM 性能(适合小项目,读快速)MyISAM 是MySQL中默认的存储引擎,比如适合新闻系统,读为主.InnoDB 事务或外键支持(适合大项目,高并发读写)活跃用户20多万时候,也能很轻松应付 ...
- MySql的多存储引擎架构, 默认的引擎InnoDB与 MYISAM的区别(滴滴)
1.存储引擎是什么? MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力.通过选择不同的技术, ...
- MySQL存储引擎——InnoDB和MyISAM的区别
MySQL5.5后,默认存储引擎是InnoDB,5.5之前默认是MyISAM. InnoDB(事务性数据库引擎)和MyISAM的区别补充: InnoDB是聚集索引,数据结构是B+树,叶子节点存K-V, ...
- MySQL存储引擎InnoDB与MyISAM的区别
一.比较 事务:InnoDB是事务型的,可以使用Commit和Rollback语句. 并发:MyISAM只支持表级锁,InnoDB还支持行级锁. 外键:InnoDB支持外键. 备份:InnoDB支持在 ...
- mysql中innodb和myisam的区别
InnoDB和MyISAM是很多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,5.7之后就不一样了 1.事务和外键 InnoDB具有事务,支持4个事务隔离级别,回滚,崩溃修复能力和多版 ...
- MySQL存储引擎 InnoDB与MyISAM的区别
来源:http://www.jb51.net/article/47597.htm 基本的差别:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能,其执行 ...
- mysql 存储引擎 InnoDB 与 MyISAM 的区别和选择
http://www.blogjava.net/jiangshachina/archive/2009/05/31/279288.html 酷壳 - MySQL: InnoDB 还是 MyISA ...
- InnoDB 与 MYISAM的区别和联系
1.存储引擎是什么? MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力.通过选择不同的技术, ...
- InnoDB与MyISAM的区别
MyISAM 和 InnoDB 讲解 InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定.基本的差别为:MyISAM类型不支持事务处理等高级处 ...
随机推荐
- EF CodeFirst 实例Demo
一直想搞一个EFCodeFirst的Demo,让自己通过实例真正了解CodeFirst,方便以后有需求的时候可以有思路.网上查了很多资料,发现很多博主的文章大量重复,根据推荐步骤走并不一定能够成功,而 ...
- oracle 用EXISTS替换DISTINCT
当提交一个包含一对多表信息(比如部门表和雇员表)的查询时,避免在SELECT子句中使用DISTINCT. 一般可以考虑用EXIST替换 例如: 低效: SELECT DISTINCT DEPT_NO, ...
- [学习笔记]整体DP
问题: 有一些问题,通常见于二维的DP,另一维记录当前x的信息,但是这一维过大无法开下,O(nm)也无法通过. 但是如果发现,对于x,在第二维的一些区间内,取值都是相同的,并且这样的区间是有限个,就可 ...
- Keras框架下的保存模型和加载模型
在Keras框架下训练深度学习模型时,一般思路是在训练环境下训练出模型,然后拿训练好的模型(即保存模型相应信息的文件)到生产环境下去部署.在训练过程中我们可能会遇到以下情况: 需要运行很长时间的程序在 ...
- nio FileChannel中文乱码问题
最近用nio读取文件时,英文正常,读取中文时会出现乱码,经查可以用Charset类来解决: 代码如下: package com.example.demo; import java.io.FileNot ...
- npm镜像及配置方法
npm全称Node Package Manager,是node.js的模块依赖管理工具.由于npm的源在国外,所以国内用户使用起来各种不方便.下面整理出了一部分国内优秀的npm镜像资源,国内用户可以选 ...
- poj 3278(hdu 2717) Catch That Cow(bfs)
Catch That Cow Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- H3C DHCP中继基本配置
- Java 5,6,7,8,9,10,11新特性吐血总结
作者:拔剑少年 简书地址:https://www.jianshu.com/u/dad4d9675892 博客地址:https://it18monkey.github.io 转载请注明出处 java5 ...
- 11-28-----vertor和list使用场景
1.vector拥有一段连续的内存空间,因此支持随机访问,如果需要高效的随机访问,而不子啊胡插入和删除的效率,使用vector, 2.list拥有一段不连续的内存空间,如果需要高效的插入和删除,而不关 ...