【软考002】事务管理

文章介绍了数据库在多用户并发访问时如何维护数据完整性,主要通过一级、二级、三级封锁协议和两段锁协议来控制并发操作。两段锁协议确保并发调度的可串行化,但也可能导致死锁。活锁和死锁是并发执行中的问题,可以通过预防法和解除法来避免。此外,文章提及事务的四大特性对系统稳定性至关重要。
摘要由CSDN通过智能技术生成

数据库是一个共享资源, 它允许多个用户程序并行地存取数据库中的数据, 但是, 如果系统对并行操作不加以控制, 就会存取不正确的数据, 破坏数据库的完整性。在多个事务并发执行的系统中, 主要采取封锁协议来进行处理。

1、数据库的一级、二级、三级封锁协议

2、两段锁协议(Two-phase Locking Protocol)

两段锁协议是指对任何数据进行读写之前必须对数据进行加锁;在释放一个封锁之后,事务不再申请和获得任何其他封锁。

  • 两段锁协议中两段的含义:事务分为两个阶段,第一个获得封锁称为扩展阶段;第二阶段为释放阶段,也称为收缩阶段。
  • 两段锁协议的目的:保证并发调度的正确性。
  • 两段锁协议与可串行化:如果事务都遵循两段锁协议,那么它们的并发调度是可串行化。两段锁是可串行化的充分条件,但不是必要条件。如果事务不遵循两段锁协议,它们的并发调度有可能不是可串行化的。
  • 说明:采用两段锁协议会有可能产生死锁的情况,因为每个事务不能及时解除被它封锁的数据,可能会导致多个事务互相要求对方已封锁的数据而产生死锁。另外要注意两段锁协议和防止死锁的一次封锁法的异同之处。一次封锁法要求每个事务必须一次将所有要使用的数据全部加锁,否则就不能继续执行,因此一次封锁法遵守两段锁协议;但是两段锁协议并不要求事务必须一次将所有要使用的数据全部加锁,因此遵守两段锁协议的事务可能发生死锁。

3、活锁、死锁介绍

  • 活锁:主要是指事务T1封锁了数据R,事务T2请求封锁数据R,于是T2等待R的封锁被释放。当T1释放数据R上的封锁后,系统批准了T3事务的请求,于是T2仍然等待。如果T3释放后,又批准了T4的请求,那么T2可能会永远等待的现象。
  • 死锁:主要是指两个以上的事务分别请求封锁对方已经封锁的数据,导致长期等待而无法继续运行下去的现象。
一般来讲, 死锁是可以避免的, 目前采用的办法有以下几种:
  • 预防法: 此种方法是采用一定的操作方式以保证避免死锁的出现, 顺序申请法、一次申请法等即是此类方法。 所谓顺序申请法是指对封锁对象按序编号, 在用户申请封锁时必须按编号顺序(从小到大或反之) 申请, 这样能避免死锁发生。 所谓一次申请法即是指用户在一个完整操作过程中必须一次性申请它所需要的所有封锁, 并在操作结束后一次性归还所有封锁, 这样也能避免死锁的发生。
  • 死锁的解除法: 此种方法允许产生死锁, 并在死锁产生后通过解锁程序以解除死锁。 这种方法需要有两个程序, 一是死锁检测程序, 用它测定死锁是否发生, 另一是解锁程序, 一旦经测定系统已产生死锁则启动解锁程序以解除死锁。 有关死锁检测及解锁技术请参阅相应的资料, 这里不做进一步讨论。

4、事务的四大特性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值