大家都知道在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万条测试数据,如下:
文章插图
文章插图
文章插图
文章插图
这里我们字段都采用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();}
推荐阅读
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 半边头皮和耳朵里痛
- 屁股中间痛是怎么回事
- 中国什么时候办第一届残奥会
- 饮中八仙分别是谁 饮中八仙
- 中国十大茶叶品牌 十大茶叶品牌
- 中公教育|教师考编试题:浙江教师招聘考试练习题07-12
- 中暑的症状是什么 中暑的症状及治疗
- |职场中需要记住这几件事,永远不要做这几件事,职场法则
- 中国农业银行如何查余额
- 冬季怎样预防一氧化碳中毒出现 一氧化碳中毒原理