试题详情
简答题叙述数据库中死锁产生的原因和解决死锁的方法。
  • 死锁产生的原因:
    封锁可以引起死锁。比如事务T1封锁了数据A,事务T2封锁了数据B。T1又申请封锁数据B,但因B被T2封锁,所以T1只能等待。T2又申请封锁数据A,但A已被T1封锁,所以也处于等待状态。这样,T1和T2处于相互等待状态而均不能结束,这就形成了死锁。解决死锁的常用方法有如下三种:
    (1)要求每个事务一次就要将它所需要的数据全部加锁。
    (2)预先规定一个封锁顺序,所有的事务都要按这个顺序实行封锁。
    (3)允许死锁发生,当死锁发生时,系统就选择一个处理死锁代价小的事务,将其撤消,释放此事务持有的所有的锁,使其他事务能继续运行下去。
  • 关注下方微信公众号,在线模考后查看

热门试题