Oracle锁的运行机制原理的描述

以下的文章抓哟是对Oracle锁的运行机制原理的描述,我们大家都知道在现代的多用户与多任务系统中,出现多个用户同时访问共享的某个对象的几率特别大,这个对象可能是表,行,或者内存结构。

为了解决多个用户并发性访问带来的数据的 安全性,完整性及一致性问题,必须要有一种机制。

来使对这些共享资源的并发性访问串行化,Oracle锁就可以提供这样的功能,当事务在对某个对象进行操作前,先向系统发出请求,对其加相应的锁,加锁后该事务就对该数据对象有了一定的控制权限,在该事务释放锁之前,其他的事务不能对此数据对象进行更新操作(可以做select动作,但select 利用的是undo中的前镜像数据了).

Oracle锁的分类

Oracle锁基本上可以分为二类

a:共享锁(share locks) 也称读锁,s锁

b:排它锁 (exclusive locks) 也称写锁,x锁

在数据库中 有两种基本的锁类型:排它锁(Exclusive Locks,即X锁)和共享锁(Share Locks,即S锁)。当数据对象被加上排它锁时,其他的事务不能对它读取和修改。加了共享锁的数据对象可以被其他事务读取,但不能修改。数据库利用这两 种基本的锁类型来对数据库的事务进行并发控制。

按锁保护的内容分类

Oracle提供多粒度封锁机制,按保护对象来分,据此又可以分为

a:dml锁, data locks 数据锁,用来保护数据的完整性和一致性

b:ddl锁, dictionary locks 字典锁,用来保护数据对象的结构,如table,index的定义

c:内部锁和闩 internal locks and latchs 用来保护数据库内部结构,如sga内存结构

dml锁

DML锁主要包括TM锁和TX锁,其中TM锁称为表级锁,TM锁的种类有S,X,SR,SX,SRX五种,TX锁称为事务锁或行级 锁。当Oracle执行delete,update,insert,select for update DML语句时,Oracle首先自动在所要操作的表上申请TM类型的锁。

当TM锁获得后,再自动申请TX类型的锁,并将实际锁定的数据行的锁标志位(lb 即lock bytes)进行置位。在记录被某一会话锁定后,其他需要访问被锁定对象的会话会按先进先出的方式等待锁的释放,对于select操作而言,并不需要任何 Oracle锁,所以即使记录被锁定,select语句依然可以执行,实际上,在此情况下,Oracle是用到undo的内容进行一致性读来实现的。

在 Oracle数据库中,当一个事务首次发起一个DML语句时就获得一个TX锁,该锁保持到事务被提交或回滚。在数据行上只有X锁(排他锁),就是说TX锁 只能是排他锁,在记录行上设置共享锁没有意义。当两个或多个会话在表的同一条记录上执行DML语句时,第一个会话在该条记录上加锁,其他的会话处于等待状 态。当第一个会话提交后,TX锁被释放,其他会话才可以加锁。

在数据表上,Oracle默认是共享锁,在执行dml语句的时候,Oracle会先申请对象上的共享锁,防止其他会话在这个对象上做ddl语句,成功申请表上的共享锁后,再在受影响的记录上加排它所,防止其他会话对这些做修改动作。

这样在事务加锁前检查TX锁相容性时就不用再逐行检查Oracle锁标志,而只需检查TM锁模式的相容性即可,大大提高了系统的效率。TM锁包括了SS、SX、S、X等多种模式,在数据库中用0-6来表示。不同的SQL操作产生不同类型的TM锁。如表1所示。

和锁相关的性能视图介绍

v$lock

SID 会话的sid,可以和v$session 关联

TYPE 区分该锁保护对象的类型,如tm,tx,rt,mr等

ID1 锁表示1,详细见下说明

ID2 锁表示2,详细见下说明

LMODE 锁模式,见下面说明

REQUEST 申请的Oracle锁模式,同lmode

CTIME 已持有或者等待锁的时间

BLOCK 是否阻塞其他会话锁申请 1:阻塞 0:不阻塞

LMODE取值0,1,2,3,4,5,6, 数字越大锁级别越高, 影响的操作越多。

1级锁:

Select,有时会在v$locked_object出现。

2级锁即RS锁

相应的sql有:Select for update ,Lock xxx in Row Share mode,select for update当对

话使用for update子串打开一个游标时,所有返回集中的数据行都将处于行级(Row-X)独

占式Oracle锁定,其他对象只能查询这些数据行,不能进行update、delete或select for update

操作。

【编辑推荐】

  1. 用Oracle SQL语句来实现进制间的相互转换
  2. Oracle数据库与FoxPro数据如何转换
  3. Oracle安全策略的实际用法
  4. Oracle数据库中的(+)连接如何操作?
  5. Oracle 10G数据库中软硬件环境有哪些要求?

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/288623.html<

(0)
运维的头像运维
上一篇2025-05-16 10:10
下一篇 2025-05-16 10:12

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注