1. 区别:

(1)事务处理:

MyISAM是非事务安全型的,而InnoDB是事务安全型的(支持事务处理等高级处理);

(2)锁机制不同:

MyISAM是表级锁,而InnoDB是行级锁;

(3)select ,update ,insert ,delete 操作:

MyISAM:如果执行大量的SELECT,MyISAM是更好的选择

InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表

(4)查询表的行数不同:

MyISAM:select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含   where条件时,两种表的操作是一样的

InnoDB : InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行

(5)外键支持:

mysiam表不支持外键,而InnoDB支持

2. 为什么MyISAM会比Innodb 的查询速度快。

INNODB在做SELECT的时候,要维护的东西比MYISAM引擎多很多;
1)数据块,INNODB要缓存,MYISAM只缓存索引块,  这中间还有换进换出的减少; 
2)innodb寻址要映射到块,再到行,MYISAM 记录的直接是文件的OFFSET,定位比INNODB要快
3)INNODB还需要维护MVCC一致;虽然你的场景没有,但他还是需要去检查和维护

MVCC ( Multi-Version Concurrency Control )多版本并发控制

3. 应用场景

MyISAM适合:(1)做很多count 的计算;(2)插入不频繁,查询非常频繁;(3)没有事务。

InnoDB适合:(1)可靠性要求比较高,或者要求事务;(2)表更新和查询都相当的频繁,并且行锁定的机会比较大的情况。

最新文章

  1. JS魔法堂之实战:纯前端的图片预览
  2. Atitit.数据索引 的种类以及原理实现机制 索引常用的存储结构
  3. UILabel笔记(待完善)
  4. Java基础-布局
  5. python之range(), xrange()
  6. mybatis-generator-core自动生成do、mapping、dao 代码
  7. 微软未公开的 SP
  8. 关于禁止ViewPager预加载问题【转】
  9. ajax调用webservice(二) 跨域。
  10. PHP MYSQL读取中文乱码的解决办法
  11. JS输出当前时间,且每秒变化
  12. Python IDLE 运行错误:IDLE's subprocess didn't make connection. --已解决(原创)!
  13. hdu3240 Counting Binary Trees
  14. java 遍历树节点 同时保留所有的从根到叶节点的路径
  15. cocos2d-x注意事项(十)Lua发展飞机战争-4-创建主角
  16. Condition线程通信(七)
  17. 利用python脚本(re)抓取美空mm图片
  18. pta-3
  19. node 命令行升级版本
  20. php parse_url 解析URL并返回其组成部分

热门文章

  1. 利用YYLabel 进行图文混排+高度计算
  2. UTF-8和Unicode互转
  3. 5-5 城市间紧急救援 (25分)【最短路spfa】
  4. Unity Prefabs
  5. Codevs 1099 字串变换
  6. 反射记录点滴——Field
  7. win10子系统linux编译ffmpeg
  8. socket模拟服务器,客户端下载东西(ftp)
  9. Php对象及对象特性篇
  10. [转]Cordova android框架详解