`

Oracle行级锁和表级锁

 
阅读更多
1、DML锁包括行级锁(TX)和表级锁(TM) 2、行级锁不是单独存在的,当事务获得了某些数据行上的行级锁时,此事务同时获得了数据行所属表上的表级锁,因为表级锁能够防止系统中并发地执行有冲突的 DDL 操作,避免当前事务中的数据操作被并发地DDL 操作影响。
行级锁
可以用select * from table t where t.a='b' for update;

表级锁
lock table table_name



1、DML锁包括行级锁(TX)和表级锁(TM)
2、行级锁不是单独存在的,当事务获得了某些数据行上的行级锁时,此事务同时获得了数据行所属表上的表级锁,因为表级锁能够防止系统中并发地执行有冲突的 DDL 操作,避免当前事务中的数据操作被并发地DDL 操作影响。
3、表级锁分为5种,限制程度升序排列:
   (1)行共享(row share):与行排他类似,区别是别的事务还可以在此表上加任何排他锁。(除排他(exclusive)外)
   (2)行排他(row exclusive):其他事务依然可以并发地对相同数据表执行查询,插入,更新,删除操作,或对表内数据行加锁的操作,但不能有其他的排他锁(自身是可以的,没发现有什么用)
   (3)共享(share):在表没有被任何DML操作时,多个事务都可加锁,但只有在仅一个事务加锁的情况下只有此事务才能对表更新;当表已经被更新或者指定要更新时(select for update),任何事务都不能加此锁了。
   (4)共享行排他(share row exclusive):在表没有被任何DML操作时,只有一个事务可以加锁,可以更新,书上说别的事务可以使用select for update锁定选中的数据行,可是实验后没被验证。
   (5)排他(exclusive):在表没有被任何DML操作时,只有一个事务可以加锁,可以更新,与共享行排他的区别还没有发现
分享到:
评论

相关推荐

    MySQL中的行级锁、表级锁、页级锁

    MySQL数据库在处理并发操作时,为了保证数据的一致性和完整性,使用了不同的锁机制,包括行级锁、表级锁和页级锁。这三种锁的粒度不同,各有优缺点,适用于不同的场景。 行级锁是MySQL中最细粒度的锁,仅锁定操作的...

    Oracle的锁表与解锁

    锁可以分为行级锁(Row Level Lock)和表级锁(Table Level Lock),以及更细粒度的锁类型。本文将深入探讨Oracle中的锁机制,特别是如何锁表与解锁,以及相关的SQL查询语句,帮助数据库管理员和开发人员更好地理解...

    oracle常见的锁查询和处理

    Oracle数据库的锁机制是保证数据并发访问安全的重要手段,它主要分为行级锁(TX锁)和表级锁(TM锁)。行级锁确保在多用户环境下,同一时间只有一个用户可以更新特定的数据行,而其他用户可以读取,但不能进行修改。...

    Oracle锁和表分区

    Oracle支持多种级别的锁,包括行级锁和表级锁。 - **行级锁**:行级锁只锁定特定的行,避免了不同用户对同一行数据的冲突。例如,当用户执行`SELECT...FOR UPDATE`语句时,Oracle会在选定的行上设置一个排他锁,...

    Oracle行级锁的特殊用法简析

    Oracle行级锁是数据库管理系统中用于确保数据并发访问安全的重要机制。它主要针对单个行或者一组行进行锁定,以防止多个事务同时修改相同的数据,从而避免数据的不一致性。行级锁相比于表级锁提供了更高的并发性能,...

    Oracle五种表级排他锁的总结和归纳

    共享行排他锁是一种介于行级共享锁和行级排他锁之间的锁,它允许其他事务添加行级共享锁,但不允许添加行级排他锁。拥有 SRX 锁的事务可以执行更新操作,但其他事务只能进行 `SELECT` 查询。加锁语句为 `Lock Table ...

    Oracle的锁机制

    按锁的粒度,Oracle有行级锁和表级锁。行级锁更细粒度,减少锁冲突,提高并发性。表级锁则更大粒度,易于管理,但可能导致更大的锁定范围。共享锁(S)、排它锁(X)、行级共享锁(RS)、行级排它锁(RX)和共享行级...

    oracle中锁和表分区

    Oracle数据库中的锁和表分区是两个重要的概念,它们在数据管理与并发控制中起到关键作用。锁用于确保数据的一致性和完整性,而表分区则是一种优化查询性能的技术。 首先,让我们详细了解一下锁。在Oracle中,锁是...

    对于Oracle锁的一些理论总结

    DML锁是本文的重点,它包括行级锁(row level lock)和表级锁(table level lock)。 1. 行级锁(TX):Oracle的行级锁并不像其他数据库那样,对每一行数据都单独加锁。实际上,Oracle采用事务级的行级锁,即TX锁。...

    oracle锁表及解锁

    Oracle中的锁主要有两种类型:表级锁(Table Locks)和行级锁(Row Locks),分别由`TM`和`TX`标识。表级锁通常用于DML操作或DDL操作,而行级锁则是在执行更新、插入或删除等操作时自动产生的。 #### 检查锁定情况 ...

    Oracle数据库的锁类型

    DML锁主要关注的是数据级别的锁控,包括TM锁(表级锁)和TX锁(事务锁或行级锁)。这些锁在执行DML(数据操纵语言)操作时自动触发,以确保数据在并发环境下的完整性和一致性。 ##### 1. TM锁:表级锁 TM锁是针对...

    表级锁(TM锁) 表级锁(TM锁) 表级锁(TM锁) 表级锁(TM锁)

    当用户A对employee_id为100的记录进行更新时,Oracle会在数据行头部添加行级锁,并且同时在表级别上设置一个表级锁。这样,当用户D尝试删除该表时,会检测到表上的TM锁,进而阻止删除操作,直到用户A的事务完成并...

    oracle锁机制探讨

    在Oracle数据库中,DML锁主要包括TM锁和TX锁,其中TM锁称为表级锁(用来保证表的结构不被用户修改),TX锁称为事务锁或行级锁。当Oracle执行DML语句时,系统自动在所要操作的表上申请TM类型的锁。当TM锁获得后,系统...

    Oracle分区表和锁的应用

    - **表级锁(TABLE LOCK)**:锁定整个表,适用于全表扫描或批量操作。 - **行级意向锁(INTENTION LOCKS)**:用于多粒度锁定,表明接下来的锁定将是行级或表级。 2. **锁模式**: - **共享锁(SHARE LOCK)**...

    Oracle数据库锁的研究.pdf

    2. 按照锁的粒度划分,主要有行级锁和表级锁: - 行级锁:锁定单个数据行,只允许事务修改锁定的行,其他用户可以访问未锁定的行。在事务进行DML操作时,Oracle会自动施加行级锁。 - 表级锁:锁定整个表,确保表...

    oracle数据库锁表处理

    2. **表级锁**:作用于整个表,影响范围较广。 3. **模式对象锁**:作用于模式对象(如表、视图等)。 4. **数据块锁**:作用于数据块,比行级锁更粗粒度。 #### 三、查看锁表情况 1. **查询锁定的对象**: ```...

    Oracle锁 图例

    1. 表级锁:Oracle中的表级锁主要有两种,即排他锁(Exclusive Locks, X locks)和共享锁(Shared Locks, S locks)。排他锁允许一个用户修改表中的数据,而共享锁则允许多个用户同时读取表,但不允许任何写操作。 ...

    oracle查锁和解锁命令

    锁分为多种类型,包括行级锁、表级锁等,每种锁都有其特定的应用场景。 #### 二、查询锁定的对象 对于数据库管理员而言,了解哪些对象被锁住以及锁的状态是非常重要的。通过SQL查询可以获取这些信息,进而判断是否...

Global site tag (gtag.js) - Google Analytics