数据库
首页 > 数据库> > 【DB笔试面试655】在Oracle中,锁分为哪几类?

【DB笔试面试655】在Oracle中,锁分为哪几类?

作者:互联网

640?wx_fmt=gif

♣  

题目         部分

在Oracle中,锁分为哪几类?


     


♣  

答案部分          


数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。并发(Concurrency)的意思是在数据库中有超过两个以上用户对同样的数据做修改,而并行(parallel)的意思就是将一个任务分成很多小的任务,让每一个小任务同时执行,最后将结果汇总到一起。所以说,锁产生的原因就是并发,并发产生的原因是因为系统和客户的需要。

在单用户数据库中,锁不是必需的,因为只有一个用户在修改信息。但是,当多个用户在访问和修改数据时,数据库必须使用锁,以防止对同一数据进行并发修改。所以,锁实现了以下重要的数据库需求:

l 一致性。一个会话正在查看或更改的数据不能被其它会话更改,直到用户会话结束。

l 完整性。数据库的数据和结构必须按正确的顺序反映对他们所做的所有更改。

数据库通过其锁定机制,提供在多个事务之间的数据并发性、一致性、和完整性。一般情况下,锁是自动执行的,并且不需要用户操作。

在执行SQL语句时,Oracle数据库自动获取所需的锁。例如,在数据库允许某个会话修改数据之前,该会话必须先锁定数据。锁给予该会话对数据的独占控制权,以便在释放该锁之前,任何其它事务都不可以修改被锁定的数据。因为数据库的锁定机制与事务控制紧密地绑定在一起,应用程序设计人员只需要正确地定义事务,而数据库会自动管理锁定。

在任何情况下,Oracle都能够自动地获得执行SQL语句所必须的所有锁,无需用户干预。Oracle会尽可能地减少锁产生的影响,从而最大程度地保证数据的并发访问能力,并确保数据一致性及错误恢复。同时,Oracle也支持用户手工加锁的操作。Oracle从来不会升级锁,但是它会执行锁转换(Lock Conversion)或锁提升(Lock Promotion)。

(一)Oracle中锁的分类

Oracle中锁的分类图如下所示:

640?wx_fmt=png

图 3-15 Oracle的锁分类

表 3-24 Oracle中锁的分类

640?wx_fmt=png

640?wx_fmt=png

在上表中的TM锁又分为7个级别,其中,R代表行,S代表共享,如下表所示:

表 3-25 TM锁级别

640?wx_fmt=png


640?wx_fmt=png

(二)锁的兼容性

常见SQL语句的锁兼容情况如下表所示:

640?wx_fmt=png

 

标签:会话,数据库,DB,用户,并发,655,Oracle,数据
来源: https://blog.51cto.com/lhrbest/2707260