`
jihongbin12329
  • 浏览: 40188 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
最近访客 更多访客>>
社区版块
存档分类
最新评论

oracle 锁同隔离机制

阅读更多

oracle 锁从不同功能可分为表结构锁同行级锁以及表锁也可分为共享锁,共享更新锁,独占锁

DML锁有如下三种封锁方式:
   (1)、共享封锁方式(SHARE)
   (2)、独占封锁方式(EXCLUSIVE)
   (3)、共享更新封锁(SHARE UPDATE)
   其中SHARE,EXCLUSIVE用于表封锁,SHARE UPDATE用于行封锁。

   1、共享方式的表封锁
   共享方式的表封锁是对表中的所有数据进行封锁,该锁用于保护查询数据的一致性,防止其它用户对已封锁的表进行更更新。其它用户只能对该表再施加共享方式的锁,而不能再对该表施加独占方式的封锁,共享更新锁可以再施加,但不允许持有共享更新封锁的进程做更新。共享该表的所有用户只能查询表中的数据,但不能更新。共享方式的表封锁只能由用户用SQL语句来设置,基语句格式如下:
   [quote:04b72348bd]LOCK TABLE <表名>[,<表名>]...
   IN SHARE MODE [NOWAIT]
   [/quote:04b72348bd]
   执行该语句,对一个或多个表施加共享方式的表封锁。当指定了选择项NOWAIT,若该封锁暂时不能施加成功,则返回并由用户决定是进行等待,还是先去执行别的语句。
持有共享锁的事务,在出现如下之一的条件时,便释放其共享锁:
   A、执行COMMIT或ROLLBACK语句。
   B、退出数据库(LOG OFF)。
   C、程序停止运行。
   共享方式表封锁常用于一致性查询过程,即在查询数据期间表中的数据不发生改变。

   2、独占方式表封锁
   独占方式表封锁是用于封锁表中的所有数据,拥有该独占方式表封锁的用户,即可以查询该表,又可以更新该表,其它的用户不能再对该表施加任何封锁(包括共享、独占或共享更新封锁)。其它用户虽然不能更新该表,但可以查询该表。
   独占方式的表封锁可通过如下的SQL语句来显示地获得:
   LOCK TABLE <表名>[,<表名>]....
   IN EXCLUSIVE MODE [NOWAIT]
   独占方式的表封锁也可以在用户执行DML语句INSERT、UPDATE、DELETE时隐含获得。
   拥有独占方式表封锁的事务,在出现如下条件之一时,便释放该封锁: <BR>(1)、执行   COMMIT或ROLLBACK语句。
   (2)、退出数据库(LOG OFF)
   (3)、程序停止运行。
   独占方式封锁通常用于更新数据,当某个更新事务涉及多个表时,可减少发生死锁。

   3、共享更新封锁方式
   共享更新封锁是对一个表的一行或多行进行封锁,因而也称作行级封锁。表级封锁虽然保证了数据的一致性,但却减弱了操作数据的并行性。行级封锁确保在用户取得被更新的行到该行进行更新这段时间内不被其它用户所修改。因而行级锁即可保证数据的一致性又能提高数据操作的迸发性。
   可通过如下的两种方式来获得行级封锁:
   (1)、执行如下的SQL封锁语句,以显示的方式获得:
   LOCK TABLE <表名>[,<表名>]....
   IN SHARE UPDATE MODE [NOWAIT]
   (2)、用如下的SELECT ...FOR UPDATE语句获得:
   SELECT <列名>[,<列名>]...
   FROM <表名>
   WHERE <条件>
   FOR UPDATE OF <列名>[,<列名>].....[NOWAIT]
   一旦用户对某个行施加了行级封锁,则该用户可以查询也可以更新被封锁的数据行,其它用户只能查询但不能更新被封锁的数据行.如果其它用户想更新该表中的数据行,则也必须对该表施加行级锁.即使多个用户对一个表均使用了共享更新,但也不允许两个事务同时对一个表进行更新,真正对表进行更新时,是以独占方式封锁表,一直到提交或复原该事务为止。行锁永远是独占方式锁。
   当出现如下之一的条件,便释放共享更新锁:
   (1)、执行提交(COMMIT)语句;
   (2)、退出数据库(LOG OFF)
   (3)、程序停止运行。
   执行ROLLBACK操作不能释放行锁。

一般来说不会进行锁全表操作UPDATE INSERT DELETE 大部分是进行行级锁也是独占锁如这个语句:update table_name set column_name='123'  where id="1256".  如果进行表结构更改如加列删列会进行表结构锁

 

l          设置一个事务的隔离级别
l         SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
l         SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
l         SET TRANSACTION READ ONLY;
l         设置增个会话的隔离级别
l         ALTER SESSION SET ISOLATION_LEVEL SERIALIZABLE;
l         ALTER SESSION SET ISOLATION_LEVEL READ COMMITTED;
 

 

 

分享到:
评论

相关推荐

    Oracle 锁机制问题详解

    Oracle 数据库的锁机制是确保数据一致性和事务隔离性的关键组件。了解不同类型的锁以及它们如何工作对于有效地管理数据库性能和避免潜在的问题至关重要。通过合理利用 Oracle 的锁机制,可以最大限度地提高数据库...

    oracle锁表处理

    ### Oracle锁表处理 在Oracle数据库管理中,锁机制是一种重要的资源管理手段,用于控制并发事务对数据资源的访问,防止多个用户同时修改相同的数据,从而确保数据的一致性和完整性。然而,在高并发环境下,锁的争用...

    Oracle锁 图例

    总结,Oracle锁机制是数据库并发控制的核心,理解并熟练掌握锁的使用和管理对于优化数据库性能、避免并发问题至关重要。通过使用适当的工具和技巧,我们可以有效地监控和解决锁相关问题,从而提高系统的稳定性和响应...

    快速查找oracle锁对象

    在Oracle数据库管理中,"快速查找Oracle锁对象"是一个关键任务,特别是在处理并发事务和解决性能问题时。当多个用户或进程同时访问同一资源时,可能会出现锁冲突,导致某些事务等待,影响数据库的正常运行。了解如何...

    查看Oracle锁表

    ### 查看Oracle锁表 在Oracle数据库管理过程中,锁定机制是一项重要的功能,它用于确保数据的一致性和事务处理的安全性。当多个用户试图同时访问同一数据时,可能会出现并发问题,这时就需要通过锁定来控制对数据的...

    oracle数据库锁使用

    Oracle的锁机制保证了事务的隔离性,防止了并发操作导致的数据不一致。锁的兼容性决定了不同类型的锁在同一时刻可以并存的情况。例如,S锁与S锁、RS锁与RS锁、RX锁与RX锁之间是兼容的,但S锁与X锁、RS锁与X锁、RX锁...

    oracle隔离机制

    Oracle隔离机制是数据库管理系统中确保事务之间相互独立和数据一致性的关键特性。它涉及到如何处理并发事务中的数据读取和修改,以防止出现脏读、不可重复读和幻读等并发问题。在Oracle中,提供了三种不同的隔离级别...

    ORACLE锁机制深入理解

    Oracle数据库的锁机制是确保多用户并发访问时数据一致性的重要工具。在数据库环境中,当多个事务同时尝试访问和修改同一数据对象时,如果没有适当的控制,可能会导致数据的不一致性和并发问题。为了解决这些问题,...

    oracle隔离级别

    Oracle数据库的隔离级别是确保多用户环境下数据一致性、避免并发问题的关键机制。隔离级别定义了不同事务在执行过程中如何处理数据的可见性和并发操作。根据ANSI/ISO SQL92标准,有四种主要的隔离级别: 1. **未...

    Oracle多粒度封锁机制研究

    本文主要探讨了Oracle数据库中的行级锁(TX锁)和表级锁(TM锁),以及相关的意向锁机制。 首先,封锁机制的核心在于防止并发操作导致的数据不一致。在Oracle中,最基本的锁类型是排它锁(X锁)和共享锁(S锁)。X...

    Oracle多粒度封锁机制研究(锁)借鉴.pdf

    Oracle的多粒度封锁机制主要体现在行级锁(TX锁)和表级锁(TM锁)上。TX锁,也称为事务锁,是在事务执行插入、更新、删除操作或使用`SELECT ... FOR UPDATE`时获取的,它覆盖事务中所有锁定的数据行,直到事务提交...

    理解ORACLE数据库锁机制高效维护医院信息系统运行.pdf

    Oracle数据库锁机制是确保数据库并发访问安全的重要工具,尤其在医院信息系统这种高并发、数据敏感的环境中,理解并有效管理锁机制对于系统的高效运行至关重要。本文主要探讨Oracle数据库中的TM锁和TX锁机制,以及...

    MSSQL与Oracle数据库事务隔离级别与锁机制对比

    理解事务隔离级别和锁机制对于优化数据库性能和保证数据一致性至关重要。根据具体应用场景选择合适的隔离级别,并合理利用锁机制,可以在保障数据安全的同时,提高系统的并发处理能力。在MSSQL和Oracle这样的大型...

    oracle查锁和解锁命令

    #### 一、Oracle锁机制简介 在Oracle数据库中,锁是用来控制多个用户对同一数据资源访问的一种机制,目的是为了防止并发操作导致的数据不一致问题。锁分为多种类型,包括行级锁、表级锁等,每种锁都有其特定的应用...

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

    在本文中,我们将聚焦于五种表级排他锁,这些锁主要用于控制对表的访问权限和确保事务的隔离级别。排他锁是Oracle锁定策略的重要组成部分,它们限制了其他事务对特定资源的访问,以防止数据的不一致性和并发问题。 ...

    db2与oracle锁比较[归纳].pdf

    《DB2与Oracle锁比较——并发控制的深度探讨》 在数据库系统中,尤其是在多用户并发环境下,确保数据的一致性和完整性至关重要。DB2和Oracle作为两大主流的关系型数据库管理系统,都采用了并发控制机制——锁,来...

    Oracle中使用锁进行并发控制

    在Oracle数据库中,锁是一种关键机制,用于控制并发事务对数据资源的访问,从而确保数据的一致性和事务的隔离性。锁的运用是并发控制的核心,它能够在多用户环境中协调不同事务的操作,防止数据冲突和异常状态的出现...

    oracle 锁

    这篇博客文章将深入探讨Oracle锁的相关知识点。 首先,我们需要了解锁的种类。在Oracle中,主要有两种类型的锁:行级锁(Row-Level Locks)和表级锁(Table-Level Locks)。行级锁允许并发用户同时访问不同的数据行...

    关于oracle锁的分析-驴妈妈旅游网DBA

    本篇将深入解析Oracle锁的相关知识点,结合驴妈妈旅游网DBA的经验分享,以帮助你更好地理解和应用这些概念。 一、Oracle锁的类型 Oracle中的锁主要分为以下几种类型: 1. 表级锁:包括表的读锁(SHARE)和写锁...

Global site tag (gtag.js) - Google Analytics