首页 > 其他 > 详细

事务隔离机制

时间:2018-12-08 12:06:20      阅读:152      评论:0      收藏:0      [点我收藏+]

五年前在论坛上有过一次提问,如下:

 技术分享图片

下面两个问题的答案就是数据库的事务隔离机制。数据库针对外部的并发请求,也是要考虑资源抢占问题的,所以数据库针对同一记录的写请求,也是要加锁的!

最简单的方式就是针对每个请求都加锁,全部串行,这样肯定不会有问题。但这样性能很低,所以DB将锁分为了读锁和写锁,也就是常说的X锁(排他锁)和S锁(共享锁),对同一记录可以同时进入多个S锁实现并发读。再后来,DB为了进一步提高性能,采用无锁的MVVC机制(Multiversion Currency Control),既解决资源抢占,又支持事务同时读写。但性能高和事务完全隔离性无法同时满足,DB提供了4项事务隔离级别来权衡,需要用户根据自身业务来选择合适的隔离级别。隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。

1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据

2、不可重复读:事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。

3、幻读:系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。

技术分享图片

mysql默认的事务隔离级别为repeatable-read。

事务隔离机制

原文:https://www.cnblogs.com/yuzhengzhong/p/10086658.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!