`
liangjian103
  • 浏览: 176959 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Oracle 的for update行锁语法!

 
阅读更多

SELECT...FOR UPDATE 语句的语法如下:
  SELECT ... FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED];
其中:
  OF 子句用于指定即将更新的列,即锁定行上的特定列。
  WAIT 子句指定等待其他用户释放锁的秒数,防止无限期的等待。
  “使用FOR UPDATE WAIT”子句的优点如下:  <!--IWMS_AD_BEGIN-->

<script src="../../system/system60.js" type="text/javascript"></script>
<!--IWMS_AD_END-->

 

  1防止无限期地等待被锁定的行;
  2允许应用程序中对锁的等待时间进行更多的控制。
  3对于交互式应用程序非常有用,因为这些用户不能等待不确定
  4 若使用了skip locked,则可以越过锁定的行,不会报告由wait n 引发的‘资源忙’异常报告

示例:
create table t(a varchar2(20),b varchar2(20));
insert into t values('1','1');
insert into t values('2','2');
insert into t values('3','3');
insert into t values('4','4');
现在执行如下操作:
在plsql develope中打开两个sql窗口,
在1窗口中运行sql
select * from t where a='1' for update;
在2窗口中运行sql1
1. select * from t where a='1'; 这一点问题也没有,因为行级锁不会影响纯粹的select语句
再运行sql2
2. select * from t where a='1' for update; 则这一句sql在执行时,永远处于等待状态,除非窗口1中sql被提交或回滚。
如何才能让sql2不等待或等待指定的时间呢? 我们再运行sql3
3. select * from t where a='1' for update nowait; 则在执行此sql时,直接报资源忙的异常。
若执行 select * from t where a='1' for update wait 6; 则在等待6秒后,报 资源忙的异常。
如果我们执行sql4
4. select * from t where a='1' for update nowait skip Locked; 则执行sql时,即不等待,也不报资源忙异常。
现在我们看看执行如下操作将会发生什么呢?
在窗口1中执行:
select * from t where rownum<=3 nowait skip Locked;
在窗口2中执行:
select * from t where rownum<=6 nowait skip Locked;
select for update 也就如此了吧,insert、update、delete操作默认加行级锁,其原理和操作与select for update并无两样。
select for update of,这个of子句在牵连到多个表时,具有较大作用,如不使用of指定锁定的表的列,则所有表的相关行均被锁定,若在of中指定了需修改的列,则只有与这些列相关的表的行才会被锁定。

分享到:
评论

相关推荐

    ORACLE游标中的多表UPDATE行锁讨论.pdf

    本文主要探讨了Oracle游标中的多表UPDATE行锁及其解决方案。 Oracle的锁定机制主要包括共享封锁、独占封锁和共享更新封锁。共享更新封锁是一种行级封锁,它允许用户在获取锁定的数据行上进行读取和更新,但阻止其他...

    Oracle基本建表语句

    SELECT * FROM stu_account t WHERE t.count_id=2 FOR UPDATE; ``` #### 五、约束操作 约束是确保数据完整性和正确性的关键机制。 **1. 添加外键约束** **语法:** ```sql ALTER TABLE &lt;table_name&gt; ADD ...

    Oracle开发基础

    - **语法**: `SELECT * FROM 表名 WHERE 条件 FOR UPDATE;` - **示例**: `SELECT * FROM stu_account tw WHERE tw.count_id = 2 FOR UPDATE;` - **解释**: 对`stu_account`表中`count_id`为2的记录施加行级锁,...

    Oracle 基本建表语句集

    SELECT * FROM stu_account tw WHERE tw.count_id=2 FOR UPDATE; ``` - **说明**:此命令用于获取`stu_account`表中`count_id`为2的记录的行锁。当执行此命令时,其他用户或会话将无法修改该行直到当前会话释放锁...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

     删除HKDY_LOCAL_MACHINE/SOFTWARE/ODBC/ODBCINST.INI中除Microsoft ODBC for Oracle注册表键以外的所有含有Oracle的键。  删除环境变量中的PATHT CLASSPATH中包含Oracle的值。  删除“开始”/“程序”中所有...

    oracle数据开发

    Oracle SQL支持标准SQL语法,如SELECT、INSERT、UPDATE、DELETE,以及更高级的子查询、联接、分组和聚合函数等。掌握SQL语句的编写和优化对于数据查询和处理至关重要。 3. **PL/SQL编程**:PL/SQL是Oracle特有的...

    Oracle面试题

    - SQL语言:掌握SQL的基本语法,包括SELECT、INSERT、UPDATE、DELETE语句的使用。 2. **数据库体系结构** - 实例与数据库:理解实例和数据库的关系,以及SGA(System Global Area)和PGA(Program Global Area)...

    Oracle9i的init.ora参数中文说明

    只有行锁将用于SELECT FOR UPDATE, 但在更新时将获取表锁。 值范围: ALWAYS | DEFAULT | INTENT 默认值: ALWAYS shared_servers 说明 : 指定在启动例程后, 要为共享服务器环境创建的服务器进程的数量。 值范围: ...

    oracle9i初始化参数中文说明

    设置为 `INTENT` 时,对于 `SELECT FOR UPDATE` 查询使用行锁,但在更新时获取表锁。 - **值范围**:`ALWAYS`、`DEFAULT` 或 `INTENT` - **默认值**:`ALWAYS` #### shared_servers 参数 - **说明**:该参数指定了...

    MySQL初级与高级教程

    - 创建触发器:`CREATE TRIGGER trigger_name BEFORE/AFTER {INSERT|UPDATE|DELETE} ON table_name FOR EACH ROW ...`。 - 触发时机:BEFORE/AFTER。 4. **事务处理** - 事务的基本概念:一组SQL操作,要么全部...

    MySQL管理之道 性能调优、高可用与监控.part2.rar

    3.3.8 update忘加where条件误操作恢复(模拟oracle闪回功能) 99 3.3.9 delete忘加where条件误操作恢复(模拟oracle闪回功能) 108 第4章 同步复制报错故障处理 112 4.1 最常见的3种故障 112 4.1.1 在master上...

Global site tag (gtag.js) - Google Analytics