♣
题目 部分
在Oracle中,锁分为哪几类?
♣
答案部分
数据库是一个多用户使用的共享资源。当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一数据的情况。若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性。并发(Concurrency)的意思是在数据库中有超过两个以上用户对同样的数据做修改,而并行(parallel)的意思就是将一个任务分成很多小的任务,让每一个小任务同时执行,最后将结果汇总到一起。所以说,锁产生的原因就是并发,并发产生的原因是因为系统和客户的需要。
在单用户数据库中,锁不是必需的,因为只有一个用户在修改信息。但是,当多个用户在访问和修改数据时,数据库必须使用锁,以防止对同一数据进行并发修改。所以,锁实现了以下重要的数据库需求:
l 一致性。一个会话正在查看或更改的数据不能被其它会话更改,直到用户会话结束。
l 完整性。数据库的数据和结构必须按正确的顺序反映对他们所做的所有更改。
数据库通过其锁定机制,提供在多个事务之间的数据并发性、一致性、和完整性。一般情况下,锁是自动执行的,并且不需要用户操作。
在执行SQL语句时,Oracle数据库自动获取所需的锁。例如,在数据库允许某个会话修改数据之前,该会话必须先锁定数据。锁给予该会话对数据的独占控制权,以便在释放该锁之前,任何其它事务都不可以修改被锁定的数据。因为数据库的锁定机制与事务控制紧密地绑定在一起,应用程序设计人员只需要正确地定义事务,而数据库会自动管理锁定。
在任何情况下,Oracle都能够自动地获得执行SQL语句所必须的所有锁,无需用户干预。Oracle会尽可能地减少锁产生的影响,从而最大程度地保证数据的并发访问能力,并确保数据一致性及错误恢复。同时,Oracle也支持用户手工加锁的操作。Oracle从来不会升级锁,但是它会执行锁转换(Lock Conversion)或锁提升(Lock Promotion)。
(一)Oracle中锁的分类
Oracle中锁的分类图如下所示:
图 3-15 Oracle的锁分类
表 3-24 Oracle中锁的分类
在上表中的TM锁又分为7个级别,其中,R代表行,S代表共享,如下表所示:
表 3-25 TM锁级别
(二)锁的兼容性
常见SQL语句的锁兼容情况如下表所示: