全部科目 > 数据库系统工程师 >
2019年上半年 上午试卷 综合知识
第 60 题
知识点 并发控制技术   两段锁协议  
章/节 事务管理  
 
 
下面说法中错误的是( )。
 
  A.  并发事务如果不加控制,可能会破坏事务的隔离性
 
  B.  可串行化调度是正确的调度
 
  C.  两段锁协议能够保证可串行化调度
 
  D.  两段锁协议能够确保不会产生死锁
 
 




 
 
相关试题     并发操作、并发调度与并发控制 

  第60题    2020年下半年  
如果一个事务已获得数据项R上的共享锁,则其他事务( )。

  第51题    2020年下半年  
事务T1将数据库中的A值从50改为30,事务T2读A值为30,事务T1又将刚才的操作撤销,A值恢复为50。这种情况属于(51), 是由于数据库系统在(52)方面的不当引起的,能解决此问题的方法是(53)。..

  第55题    2018年上半年  
为了防止一个事务的执行影响其他事务,应该采取()。

相关试题     封锁协议 

  第54题    2015年上半年  
如右图所示的调度,其中事务T1、T2仅对数据项A、B进行操作,则该调度( );

  第54题    2021年上半年  
下表是某两个事务并发执行时的调度过程,这里不会出现不可重复读的问题,是因为这两个事务都使用了(53);
两个事务的并行执行结果是正确的,是因为这两个事务都使用了(54);
..

  第58题    2022年上半年  
要求事务在读数据前必须先加S锁,读完后即释放的协议是()。

 
知识点讲解
· 并发控制技术
· 两段锁协议
 
        并发控制技术
        通过上面的例子我们知道,并发事务如果对数据读写时不加以控制,会破坏事务的隔离性和一致性。为了保持事务的隔离性,系统必须对事务之间的相互作用加以控制,最典型的方式是要求对数据对象以互斥的方式进行访问,即当一个事务访问某个数据对象时,其他事务都不能更新该数据对象。最常用的控制的手段就是加锁,该方法是只允许事务访问当前持有锁的数据项。给数据对象加锁的方式有多种,本节只介绍两种锁:排它锁和共享锁。
        排它锁(Exclusive Locks,简称X锁)也称为写锁,用于对数据进行写操作时进行锁定。如果事务T对数据A加上X锁后,就只允许事务T读取和修改数据A,其他事务对数据A不能再加任何锁,从而也不能读取和修改数据A,直到事务T释放A上的锁。
        共享锁(Share Locks,简称S锁)也称为读锁,用于对数据进行读操作时进行锁定。如果事务T对数据A加上了S锁后,事务T就只能读数据A但不可以修改,其他事务可以再对数据A加S锁来读取,只要数据A上有S锁,任何事务都只能再对其加S锁读取而不能加X锁修改。
 
        两段锁协议
        通过对数据加锁,可以限制其他事务对数据的访问,但这会降低事务的并发性。如何在保证事务的一致性的前提下尽可能地提高并发性,这需要封锁协议来解决。封锁协议是对数据加锁类型、加锁时间和释放锁时间的一些规则的描述。封锁协议主要有三级封锁协议,以及两段锁协议。
               封锁协议
               封锁协议有三个级别:一级封锁协议、二级封锁协议和三级封锁协议。具体描述如下:
               (1)一级封锁协议:是事务T在修改数据A之前必须先对其加X锁,直到事务结束才释放X锁。一级封锁协议使得在一个事务修改数据期间,其他事务不能对该数据进行修改,只能等到该事务结束,解决了丢失修改的问题。
               (2)二级封锁协议:是一级封锁协议加上事务T在读取数据A之前必须对其加上S锁,读完后即可释放S锁。二级封锁协议使得一个事务不能读取被其他事务修改中的数据。解决了读脏数据的问题。但是,如果事务T在读取数据A之后,其他事务再对A做完修改,事务T再读取A,还会产生不可重复读的错误。
               (3)三级封锁协议:是一级封锁协议加上事务T在读取数据A之前必须对其加上S锁,直到事务结束才释放S锁。三级封锁协议使得一个事务读取数据期间,其他事务只能读取该数据而不能修改,解决了不可重复读的问题。
               两段锁协议
                      两段锁协议(Two-phase locking Protocol)
                      两段锁协议是指对任何数据进行读写之前必须对该数据加锁;在释放一个封锁之后,事务不再申请和获得任何其他封锁。
                      所谓“两段”锁的含义是:事务分为两个阶段。第一阶段是获得封锁,也称为扩展阶段;第二阶段是释放封锁,也称为收缩阶段。
                      例如:如果事务T1和T2的封锁序列如下,则T1遵守两段锁协议而T2不遵守两段锁协议。
                      T1的封锁序列是:Slock A …Slock B…xlock C…Unlock B…Unlock A…Unlock C
                      T2的封锁序列是:Slock A…Unlock A…Slock B…xlock C…Unlock C…Unlock B
                      为了确保事务并行执行的正确性,许多系统采用两段锁协议。同时系统设有死锁检测机制。发现死锁后按一定的算法解除死锁。
                      两段锁协议与可串行化
                      如果事务都遵循两段锁协议,那么它们的并发调度是可串行化的。两段锁是可串行化的充分条件,但不是必要条件。即如果事务不遵循两段锁协议,那么它们的并发调度可能是可串行化的,也可能是不可串行化的。
                      需要注意的是采用两段锁协议也有可能产生死锁,这是因为每个事务都不能及时解除被它封锁的数据,可能会导致多个事务互相都要求对方已封锁的数据不能继续运行。
               活锁与死锁
               所谓活锁,是指当事务T1封锁了数据R,事务T2请求封锁数据R,于是T2等待,当T1释放了R上的封锁后,系统首先批准了T3请求,于是T2仍等待,当T3释放了R上的封锁后,又批准了T4请求,依此类推,使得T2可能永远等待的现象。
               所谓死锁,是指两个以上的事务分别请求封锁对方已经封锁的数据,导致长期等待而无法继续运行下去的现象。



更多复习资料
请登录电脑版软考在线 www.rkpass.cn

京B2-20210865 | 京ICP备2020040059号-5
京公网安备 11010502032051号 | 营业执照
 Copyright ©2000-2023 All Rights Reserved
软考在线版权所有