大家都知道在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数据引擎:
主键查