MySQL中MyISAM为什么比InnoDB查询快
大家都知道在MySQL中,MyISAM比InnoDB查询快,但很多人都不知道其中的原理。
今天我们就来聊聊其中的原理,另外也验证下是否MyISAM比InnoDB真的查询快。
在探索其中原理之前,我们先验证下查询速度。
验证
下面我们一起来验证两个问题:
1、通过主键查询,MyISAM是否比InnoDB查询快?
2、通过非主键字段查询,MyISAM是否比InnoDB查询快?
验证前准备
订单表结构:
CREATE TABLE `trade` (
`id` INT(11) NULL DEFAULT NULL,
`trade_no` INT(11) NULL DEFAULT NULL,
UNIQUE INDEX `id` (`id`),
INDEX `trade_no` (`trade_no`)
)
COMMENT='订单'
COLLATE='utf8_unicode_ci'
ENGINE=InnoDB
;
分别创建不同引擎的表trade_myisam、trade_innodb,并插入10万条测试数据,如下:
这里我们字段都采用Int类型,是为了方便我们,使用区间查询,来验证查询速度。
验证思路
1、分别通过id、trade_no查询10000~20000区间的记录,并获得查询所花费时间。
2、循环查询100次,并取得查询耗费时间平均值。
3、通过对比查询
耗费
时间平均值,来判断性能。
下面我们一起来验证下,文章开头的两个问题:
1、主键查询
C#实现主键查询Id在10000~20000区间,查询耗费时间平均值代码如下:
using (var conn = new MySqlConnection(connsql))
{
conn.Open();
//查询次数
var queryTime = 1000;
//InnoDB数据引擎:
主键查询
//开始时间
var startTime = DateTime.Now;
for (var i = 0; i < queryTime; i++)
{
//插入
var sql = "select * from trade_innodb where id>=10000 and id<20000";
var sqlComm = new MySqlCommand();
sqlComm.Connection = conn;
sqlComm.CommandText = sql;
sqlComm.ExecuteScalar();
sqlComm.Dispose();
}
//完成时间
var endTime = DateTime.Now;
//耗时
var spanTime = (endTime - startTime) * 1.0 / queryTime;
Console.WriteLine("InnoDB主键查询1000次平均耗时:
" + spanTime.Minutes + "分" + spanTime.Seconds + "秒" + spanTime.Milliseconds + "毫秒");
//MyISAM数据引擎:
主键查询
//开始时间
startTime = DateTime.Now;
for (var i = 0; i < queryTime; i++)
{
//插入
var sql = "select * from trade_myisam where id>=10000 and id<20000";
var sqlComm = new MySqlCommand();
sqlComm.Connection = conn;
sqlComm.CommandText = sql;
sqlComm.ExecuteScalar();
sqlComm.Dispose();
}
//完成时间
endTime = DateTime.Now;
//耗时
spanTime = (endTime - startTime) * 1.0 / queryTime;
Console.WriteLine("MyISAM主键查询1000次平均耗时:
" + spanTime.Minutes + "分" + spanTime.Seconds + "秒" + spanTime.Milliseconds + "毫秒");
conn.Close();
}
运行结果:
通过上面的图片,可以看到结果: MyISAM查询性能确实比较Innodb快。
2、非主键查询
C#实现费主键查询trade_no在10000~20000区间,查询耗费时间平均值代码如下:
using (var conn = new MySqlConnection(connsql))
{
conn.Open();
//查询次数
var queryTime = 1000;
//InnoDB数据引擎:
非主键查询
//开始时间
var startTime = DateTime.Now;
for (var i = 0; i < queryTime; i++)
{
//插入
var sql = "select * from trade_innodb where trade_no>=10000 and trade_no<20000";
var sqlComm = new MySqlCommand();
sqlComm.Connection = conn;
sqlComm.CommandText = sql;
sqlComm.ExecuteScalar();
sqlComm.Dispose();
}
//完成时间
var endTime = DateTime.Now;
//耗时
var spanTime = (endTime - startTime) * 1.0 / queryTime;
Console.WriteLine("InnoDB非主键查询1000次平均耗时:
" + spanTime.Minutes + "分" + spanTime.Seconds + "秒" + spanTime.Milliseconds + "毫秒");
//MyISAM数据引擎:
非主键查询
//开始时间
startTime = DateTime.Now;
for (var i = 0; i < queryTime; i++)
{
//插入
var sql = "select * from trade_myisam where trade_no>=10000 and trade_no<20000";
var sqlComm = new MySqlCommand();
sqlComm.Connection = conn;
sqlComm.CommandText = sql;
sqlComm.ExecuteScalar();
sqlComm.Dispose();
}
//完成时间
endTime = DateTime.Now;
//耗时
spanTime = (endTime - startTime) * 1.0 / queryTime;
Console.WriteLine("MyISAM非主键查询1000次平均耗时:
" + spanTime.Minutes + "分" + spanTime.Seconds + "秒" + spanTime.Milliseconds + "毫秒");
conn.Close();
}
运行结果:
通过上面的图片,可以看到结果: MyISAM查询性能确实比较Innodb快。
对比结果
通过我们的验证来看,不管是主键还是非主键查询,MyISAM查询性能确实比较Innodb快。
查询速度不一样,肯定是MyISAM与InnoDB有什么区别,下面我们一起来看看它们的区别。
MyISAM与InnoDB区别
通过上面表格对比, InnoDB在做SELECT的时候,要维护的东西比MYISAM引擎多很多,影响查询速度有:
1)数据块,InnoDB要缓存,MyISAM只缓存索引块, 这中间还有换进换出的减少;
2)InnoDB寻址要映射到块,再到行,MyISAM记录的直接是文件的OFFSET,定位比InnoDB要快
3)InnoDB还需要维护MVCC一致;
虽然你的场景没有,但他还是需要去检查和维护
MVCC (Multi-Version Concurrency Control)多版本并发控制 。
索引区别:
MyISAM与InnoDB索引存储方式是不一样的(关于索引请查看《细说MySql索引原理》)。
InnoDB 的表是根据主键进行展开的 B+tree 的聚集索引。
MyISAM则非聚集型索引,MyISAM存储会有两个文件,一个是索引文件,另外一个是数据文件,其中索引文件中的索引指向数据文件中的表数据。
聚集型索引并不是一种单独的索引类型,而是一种存储方式,InnoDB 聚集型索引实际上是在同一结构中保存了 B+tree 索引和数据行。
当有聚簇索引时,它的索引实际放在叶子页中。
下面我们通过2张图,我们就能直观看到这两个引擎,索引结构的区别:
维护MVCC
InnoDB引擎还有需要实现MVCC,这里面也是损耗一定的性能的。
Innodb是通过每一行记录有2个额外的隐藏值来实现,这两个值一个记录这行数据何时被创建,另外一个记录这行数据何时过期(或者被删除)。
但是InnoDB并不存储这些事件发生时的实际时间,相反它只存储这些事件发生时的系统版本号。
这是一个随着事务的创建而不断增长的数字。
每个事务在事务开始时会记录它自己的系统版本号。
每个查询必须去检查每行数据的版本号与事务的版本号是否相同。
最后
通过我们的验证来看,不管是主键还是非主键查询,MyISAM查询性能确实比较Innodb快。
但是MyISAM不支持事务,在实现业务方面有很多麻烦的事情。
关于我们开发中,选择哪个数据引擎的问题。
平常在我们业务系统中,InnoDB数据引擎完全可以满足我们的需求,这两个引擎查询性能差别还是比较小的,完全没必要为了这点性能,给我们带来更多的工作量。
MyISAM引擎更多是用于存储数据仓库,只有查询少量插入的业务场景中,比如系统日志。
欢迎关注公众号【编程乐趣】,了解更多MySQL知识。
MySQL中MyISAM为什么比InnoDB查询快的更多相关文章
- MySQL中MyISAM引擎与InnoDB引擎性能简单测试
[硬件配置]CPU : AMD2500+ (1.8G)内存: 1G/现代硬盘: 80G/IDE[软件配置]OS : Windows XP SP2SE : PHP5.2.1DB : MySQL5.0.3 ...
- MySQL中MyISAM引擎及InnoDB引擎的缓存优化设计
MyISAM引擎中,为了提高io效率以及读取效率,将对磁盘频繁读取的索引数据加载至内存中操作. MyISAM设计了一个在存放在内存中的索引缓冲池Key Cache.Key Cache只缓存索引数据,通 ...
- Mysql中MyISAM引擎和InnoDB引擎的比较
结论 如果不清楚自己应该用什么引擎,那么请选择InnoDB,Mysql5.5+的版本默认引擎都是InnoDB,早期的Mysql版本默认的引擎是MyISAM MyISAM 和 InnoDB的适用场景 M ...
- MySQL中MyISAM和InnoDB两种主流存储引擎的特点
一.数据库引擎(Engines)的概念 MySQ5.6L的架构图: MySQL的存储引擎全称为(Pluggable Storage Engines)插件式存储引擎.MySQL的所有逻辑概念,包括SQL ...
- MySQL中MyISAM和InnoDB的区别
MyISAM和InnoDB的区别 MySQL默认采用的是MyISAM. MyISAM不支持事务,而InnoDB支持.InnoDB的AUTOCOMMIT默认是打开的,即每条SQL语句会默认被封装成一个事 ...
- 【mysql中myisam和innodb的区别】
单击进入源网页 要点摘要: 1.查看mysql存储引擎的状态mysql> show engines; 2.查看mysql默认的存储引擎mysql> show variables like ...
- MYSQL 中 MyISAM与InnoDB两者之间区别与选择,详细总结,性能对比
1.MyISAM:默认表类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的顺序访问方法) 的缩写,它是存储记录和文件的标准方法.不 ...
- MySQL中MyISAM与InnoDB的主要区别对比
特征 MyISAM InnoDB 聚集索引 否 是 压缩数据 是(仅当使用压缩行格式时才支持压缩MyISAM表.使用压缩行格式和MyISAM的表是只读的.) 是 数据缓存 否 是 加密数据 是(通过加 ...
- mysql 中 myisam innodb 的区别
区别: 1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事 ...
随机推荐
- 通过《第一行代码》学习 Android 开发
第一行代码 Android --第 2 版-- 郭霖 著 第 1 章:开始启程--你的第一行 Android 代码 •1.2 手把手带你搭建开发环境 Android Studio 的安装及配置 A ...
- 力扣 - 92. 反转链表II
目录 题目 思路1(迭代) 代码 复杂度分析 思路2(递归) 代码 复杂度分析 题目 92. 反转链表 II 思路1(迭代) 将反转链表分成3个部分:前一段未反转的部分.待反转链表部分.后一段未反转部 ...
- 第25 章 : Kubernetes 网络模型进阶
Kubernetes 网络模型进阶 本文将主要分享以下五个方面的内容: Kubernetes 网络模型来龙去脉 Pod 究竟如何上网? Service 究竟怎么工作? 啥?负载均衡还分内部外部? 思考 ...
- 第23 章 : Kubernetes API 编程范式
Kubernetes API 编程范式 需求来源 首先我们先来看一下 API 编程范式的需求来源. 在 Kubernetes 里面, API 编程范式也就是 Custom Resources Defi ...
- 常见SQL命令总结学习 -- <1>
SQL学习网练习记录 参考1:http://sample.jimstone.com.cn/xsql/Course/4.html 参考2:http://sample.jimstone.com.cn/xs ...
- 201871030117-李亚楠 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告
项目 内容 课程班级博客链接 课程班级 这个作业要求链接 作业要求 我的课程学习目标 1.体验软件项目开发中的两个人合作.练习结对编程:2.掌握Github协作开发程序的操作方法:3.熟悉编程语言的综 ...
- [面试仓库]CSS面试题汇总-定位篇
一,relative.absolute 的区别 我们还是来说常见的地方.首先就是relative,absolute的区别: relative是依据自身来定位的 absolute则是依据离其最近一层 ...
- BUAA_2020_OO_UNIT1_REVIEW
OO第一单元总结 一.程序结构分析 总的来说,这一学期我才开始正式的接触面向对象的思想,直到pre才开始正式的实践,所以这次作业可能写的有一些混乱,第三次作业也进行了大量重构. 1. 第一次作业 关于 ...
- Recoil Input 光标位置被重置到末尾的问题
考察如下代码,页面中有个输入框,通过 Recoil Atom 来存储输入的值. App.tsx function NameInput() { const [name, setName] = useRe ...
- kubernetes CRD
官方文档:https://kubernetes.io/docs/tasks/extend-kubernetes/custom-resources/custom-resource-definitions ...