我们首先来简单了解一下事务:事务首先是定义一组操作集,这组操作集要么都做,要么都不做。
比如A向B转账100元,操作集为 (1)读取A账户金额
(2)A账户金额 - 100元
(3)读取B账户金额
(4)B账户金额 + 100元
如果这组操作集,没有都执行完,只执行了几条语句,就会导致数据库数据不一致性,钱不翼而飞了。
三级封锁协议,就是在高并发环境下,有多个事务同时执行,保证数据的一致性。一,二,三级协议分别解决了,丢失修改,读脏数据,和不可重复读问题。
1.首先我们来介绍一下基本封锁类型,就是人为的定义的规则,我们必须先知道规则。
锁的类型:
X锁: (Exclusive Locks)排它锁,简记为X锁。
S锁:(Share Locks)共享锁,简记为S锁。
规则如下:①如果一个事务对 数据A加上了X锁,则不再允许其他事务加X锁或者S锁(两把锁都不能加)。
②如果一个事务对 数据A加上了S锁,那么其他事务不能对该事务加X锁,可以对事务加S锁(可以加一把S锁)。
记住这两条规则,就可以生成一个锁的相容矩阵:
一个事务对数据A加上了 X锁,那么另外一个事务对数据A,不能加X锁,不能加S锁。
一个事务对数据A加上了X锁,那么另外一个事务对数据A,不能加X锁,可以加S锁。
2.了解了以上规则之后我们就来看三个案例:T1,T2 表示两个不同的