【DB笔试面试655】在Oracle中,锁分为哪几类?
在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语句的锁兼容情况如下表所示:
本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗
---------------优质麦课------------
详细内容可以添加麦老师微信或QQ私聊。
● 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用
● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/
● 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解
● 版权所有,欢迎分享本文,转载请保留出处
● QQ:646634621 QQ群:618766405
● 提供OCP、OCM和高可用部分最实用的技能培训
● 题目解答若有不当之处,还望各位朋友批评指正,共同进步
长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。