MySQL中MyISAM为什么比InnoDB查询快

大家都知道在MySQL中,MyISAM比InnoDB查询快,但很多人都不知道其中的原理 。
今天我们就来聊聊其中的原理,另外也验证下是否MyISAM比InnoDB真的查询快 。
在探索其中原理之前,我们先验证下查询速度 。
 
验证
下面我们一起来验证两个问题:
1、通过主键查询,MyISAM是否比InnoDB查询快?
2、通过非主键字段查询,MyISAM是否比InnoDB查询快?
 
验证前准备
【MySQL中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万条测试数据,如下:

MySQL中MyISAM为什么比InnoDB查询快

文章插图
 

MySQL中MyISAM为什么比InnoDB查询快

文章插图
 

MySQL中MyISAM为什么比InnoDB查询快

文章插图
 

MySQL中MyISAM为什么比InnoDB查询快

文章插图
 
这里我们字段都采用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();   }??
运行结果:
MySQL中MyISAM为什么比InnoDB查询快

文章插图
 

MySQL中MyISAM为什么比InnoDB查询快

文章插图
 
通过上面的图片,可以看到结果: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();}


推荐阅读