存储引擎InnoDB与MyISAM区别

[align=center][size=large]存储引擎[/size][/align]

一、总结
[table]
|名称|MyISAM|InnoDB|
|事务|不支持|支持|
|外键|不支持|支持|
|数据行锁定|不支持|支持|
|数据表锁定|支持|支持|
|全文索引|支持|不支持|
|优势|查询操作多|修改操作多|
|对比|性能高执行速度快|支持事务外键|
|count(*)|读取内存中的行数|全表扫描|
|count(*) where|无差别|无差别|
|应用|(1)做很多count 的计算;(2)插入不频繁,查询非常频繁;(3)没有事务|(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都相当的频繁,并且行锁定的机会比较大的情况|
[/table]

二、其他

1.没有where的count(*)使用MyISAM要比InnoDB快得多。因为MyISAM内置了一个计数器,count(*)时它直接从计数器中读,而InnoDB必须扫描全表。所以在InnoDB上执行count(*)时一般要伴随where,且where中要包含主键以外的索引列。为什么这里特别强调“主键以外”?因为InnoDB中primary index是和raw data存放在一起的,而secondary index则是单独存放,然后有个指针指向primary key。所以只是count(*)的话使用secondary index扫描更快,而primary key则主要在扫描索引同时要返回raw data时的作用较大

2.提供行锁(locking on row level),提供与 Oracle 类型一致的不加锁读取(non-locking read in SELECTs),另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”


博文参考:
[url=http://www.cnblogs.com/lyl2016/p/5797519.html]MyISAM和InnoDB的区别[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值