[SQLyog下进行count操作]
Heap engine select count used time: 4.53 MyISAM engine select count used time: 3.28
[SQLyob下进行select操作]
速度都很快,都在1秒一下,不论是1000条记录,还是200000条记录,个人猜测可能不准确
更新操作:
[更新所有name=heiyeluren的记录为heiyeluren2,在SQLyog下执行]
Heap engine update used time: 2.500
MyISAM engine update used time: 16.000
删除操作:
[删除所有name=heiyeluren2的记录,在SQLyog下执行]
Heap engine delete used time: 51.172
MyISAM engine delte used time: 5.578
总结:
大家可以发现,Heap在插入、查询、更新操作上明显要比MyISAM快,但是删除操作稍稍有些慢,可能跟它在内存中的存储结构有关系,所以我们完全可以把Heap作为我们一个MyISAM表的一个备份,比如可以保存一些实时性要求比较高的数据,比如点击量、评论量、固定的用户信息等等,因为这些信息普遍就是插入和查询操作。
其实,Heap并没有比MyISAM快太多,这样说明我的MyISAM速度还是非常快的,所以一般情况下,MyISAM能够满足大部分的应用,如果数据太多的话,大家可以考虑把部分常用的数据保存到Heap表中,同时我们也可以结合Memcache等缓存工具来辅助缓存数据。
测试代码:
<?php
/**
* function lib
*/
function conn(){
$host = \"localhost\";
$user = \"root\";
$pass = \"\";
$db = \"test\";
$conn = mysql_connect($host, $user, $pass);
if (!$conn || !is_resource($conn)){
die(\"Connect to mysql failed: \". mysql_error());
}
mysql_select_db($db);
return $conn;
}
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/