MylSAM与InnoDB
2016-07-12 11:38
519 查看
网上的解释是:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持
所谓事务处理,就是原子性操作。
打个比方,支持事务处理的Innodb表,你要执行insert和update两个操作,假设insert成功了,update操作却没有被执行。因为两个操作没有完全成功,如果使用了事务处理,insert和update都放入到事务中去执行,这个时候,只有当insert和update两条语句都执行生成的时候才会将数据更新、写入到中,如果其中任何一条语句失败,那么就会回滚为初始状态,不执行写入。这样就保证了insert和update肯定是一同执行的。
mysiam表不支持事务处理,同时mysiam表不支持外键。
同时,在执行数据库写入的操作(insert,update,delete)的时候,mysiam表会锁表,而innodb表会锁行。通俗点说,就是你执行了一个update语句,那么mysiam表会将整个表都锁住,其他的insert和delete、update都会被拒之门外,等到这个update语句执行完成后才会被依次执行。
而锁行,就是说,你执行update语句是,只会将这一条记录进行锁定,只有针对这条记录的其他写入、更新操作会被阻塞并等待这条update语句执行完毕后再执行,针对其他记录的写入操作不会有影响。
因此,当你的数据库有大量的写入、更新操作而查询比较少或者数据完整性要求比较高的时候就选择innodb表。当你的数据库主要以查询为主,相比较而言更新和写入比较少,并且业务方面数据完整性要求不那么严格,就选择mysiam表。因为mysiam表的查询操作效率和速度都比innodb要快
所谓事务处理,就是原子性操作。
打个比方,支持事务处理的Innodb表,你要执行insert和update两个操作,假设insert成功了,update操作却没有被执行。因为两个操作没有完全成功,如果使用了事务处理,insert和update都放入到事务中去执行,这个时候,只有当insert和update两条语句都执行生成的时候才会将数据更新、写入到中,如果其中任何一条语句失败,那么就会回滚为初始状态,不执行写入。这样就保证了insert和update肯定是一同执行的。
mysiam表不支持事务处理,同时mysiam表不支持外键。
同时,在执行数据库写入的操作(insert,update,delete)的时候,mysiam表会锁表,而innodb表会锁行。通俗点说,就是你执行了一个update语句,那么mysiam表会将整个表都锁住,其他的insert和delete、update都会被拒之门外,等到这个update语句执行完成后才会被依次执行。
而锁行,就是说,你执行update语句是,只会将这一条记录进行锁定,只有针对这条记录的其他写入、更新操作会被阻塞并等待这条update语句执行完毕后再执行,针对其他记录的写入操作不会有影响。
因此,当你的数据库有大量的写入、更新操作而查询比较少或者数据完整性要求比较高的时候就选择innodb表。当你的数据库主要以查询为主,相比较而言更新和写入比较少,并且业务方面数据完整性要求不那么严格,就选择mysiam表。因为mysiam表的查询操作效率和速度都比innodb要快
相关文章推荐
- 函数式编程初探
- 网络游戏服务器注意事项,优化措施
- 【jzoj4586】【Ned的难题】【单调栈】
- iOS判断第三方SDK是否含有广告位
- java 在 Cookei中,去用户id,把用户id做成一个共享数据
- Leetcode 119. Pascal's Triangle II (Easy) (cpp)
- 连接db2数据库时NumberFormatException异常的解决方式
- .NET开发人员必看:提高ASP.NET Web应用性能的24种方法和技巧
- CENTOS 6 通过YUM升级GCC到4.7/4.8
- jquery 全选 第二次失效
- 不要因为比特币交易而增加区块大小
- Docker网络
- iOS真机测试详细步骤及图解
- spring MVC 文件上传错误
- 文本文件导入HBase中
- C#学习笔记之操作Excel
- Swift - 告警提示框(UIAlertController)的用法
- 关于安卓手机的全屏显示问题
- WinRAR 女神出击版
- ubuntu add-apt-repository: command not found 解决方案