事务管理
事务提交 commit,事务回滚 rollback。
事务:由一系列操作组成,这些操作,要么全做,要么全不做,拥有四种特性:
原子性:要么全做,要么全不做。
一致性:事务发生后数据是一致的,例如银行转账,不会存在 A 账户转出,但是B账户没收到的情况。
隔离性:任一事务的更新操作直到其成功提交的整个过程对其他事务都是不可见的,不同事务之间是隔离的,互不干涉。
持续性:事务操作的结果是持续性的。
事务是并发控制的前提条件,并发控制就是控制不同的事务并发执行,提高系统效率,但是并发控制中存在下面三个问题:
丢失更新:事务1对数据 A进行了修改并写回,事务2也对 A进行了修改并写回,此时事务 2写回的数据会覆盖事务1写回的数据,就丢失了事务1对 A的更新。即对数据 A的更新会被覆盖。
不可重复读:事务2读A,而后事务1对数据A进行了修改并写回,此时若事务2再读A,发现数据不对。即一个事务重复读A两次,会发现数据A有误。
读脏数据:事务1对数据 A进行了修改后,事务2读数据 A,而后事务1回滚,数据A恢复了原来的值,那么事务2对数据 A做的事是无效的,读到了脏数据
三级封锁协议
x锁是排它锁(写锁)。若事务对数据对象A加上×锁,则只允许读取和修改 A,其他事务都不能再对 A加任何类型的锁,直到T释放A上的锁。
S 锁是共享锁(读锁)。若事务T对数据对象A加上S锁,则只允许T读取A,但不能修改A,其他事务只能再对A加S锁(也即能读不能修改),直到T释放A上的S锁。
共分为三级封锁协议,定义如下:
一级封锁协议:事务在修改数据R之前必须先对其加×锁,直到事务结束才释放。可解决丢失更新问题。
二级封锁协议:一级封锁协议的基础上加上事务在读数据R之前必须先对其加S锁,读完后即可释放S锁。可解决丢失更新、读脏数据问题。
三级封锁协议:一级封锁协议加上事务T在读取数据R之前先对其加S锁,直到事务结束才释放。可解决丢失更新、读脏数据、数据重复读问题。
三级封锁协议的应用
丢失更新加锁;一级封锁协议:
读脏数据加锁;二级封锁协议:
不可重复读加锁;三级封锁协议: