Innodb与Myisam引擎的区别与应用场景
2018-02-23 23:24
381 查看
1. 区别:
事务处理:MyISAM是非事务安全型的,而InnoDB是事务安全型的(支持事务处理等高级处理);
锁机制不同:
MyISAM是表级锁,而InnoDB是行级锁;
select ,update ,insert ,delete 操作:
MyISAM:如果执行大量的SELECT,MyISAM是更好的选择 InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表
查询表的行数不同:
MyISAM:select count(*) from table, MyISAM只要简单的读出保存好的行数, 注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的
外键支持:
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. 表更新和查询都相当的频繁,并且行锁定的机会比较大的情况。
相关文章推荐
- MyISAM引擎和InnoDB引擎介绍及应用场景
- MyISAM和InnoDB的主要区别和应用场景
- MyISAM和InnoDB的主要区别和应用场景
- MyISAM和InnoDB的主要区别和应用场景
- MyISAM和InnoDB的主要区别和应用场景
- MyISAM和InnoDB的主要区别和应用场景
- Mysql 的存储引擎,myisam和innodb的区别
- MySQL 存储引擎InnoDB和MyISAM的区别
- mysql存储引擎myisam和innodb的区别
- mysql 数据库引擎 MyISAM InnoDB 大比拼 区别
- Mysql引擎 Innodb和MyISAM的区别
- MySQL存储引擎--MyISAM与InnoDB区别
- MySQL存储引擎 InnoDB与MyISAM的区别
- mysql存储引擎InnoDB和MyISAM的区别
- MySQL存储引擎MyISAM与InnoDB的主要区别对比
- MySQL数据库引擎MyISAM与InnoDB的区别
- MySQL存储引擎--MyISAM与InnoDB区别
- MySQL存储引擎--MyISAM与InnoDB区别
- MySQL存储引擎中的MyISAM和InnoDB区别详解
- MySQL数据库引擎MyISAM与InnoDB的区别