标签:可重复 简单的 不可重复读 管理 问题 读写 提交 strong 用户
五年前在论坛上有过一次提问,如下:
下面两个问题的答案就是数据库的事务隔离机制。数据库针对外部的并发请求,也是要考虑资源抢占问题的,所以数据库针对同一记录的写请求,也是要加锁的!
最简单的方式就是针对每个请求都加锁,全部串行,这样肯定不会有问题。但这样性能很低,所以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。
标签:可重复 简单的 不可重复读 管理 问题 读写 提交 strong 用户
原文地址:https://www.cnblogs.com/yuzhengzhong/p/10086658.html