zoukankan      html  css  js  c++  java
  • PL/SQL-FOR UPDATE 与 FOR UPDATE OF的区别

    PL/SQL-FOR UPDATE 与 FOR UPDATE OF的区别

    数据库 oracle for update of   和   for update区别     
    select * from TTable1 for update 锁定表的所有行,只能读不能写 

    2 select * from TTable1 where pkid = 1 for update 只锁定pkid=1的行 

    3 select * from Table1 a join Table2 b on a.pkid=b.pkid for update 锁定两个表的所有记录 

    4 select * from Table1 a join Table2 b on a.pkid=b.pkid where a.pkid = 10 for update 锁定两个表的中满足条件的行 

    5. select * from Table1 a join Table2 b on a.pkid=b.pkid where a.pkid = 10 for update of a.pkid 只锁定Table1中满足条件的行 

    for update 是把所有的表都锁点 for update of 根据of 后表的条件锁定相对应的表 


    ----------- 
    关于NOWAIT(如果一定要用FOR UPDATE,我更建议加上NOWAIT) 
    当有LOCK冲突时会提示错误并结束STATEMENT而不是在那里等待(比如:要查的行已经被其它事务锁了,当前的锁事务与之冲突,加上nowait,当前的事务会结束会提示错误并立即结束 STATEMENT而不再等待). 

    如果加了for update后 该语句用来锁定特定的行(如果有where子句,就是满足where条件的那些行)。当这些行被锁定后,其他会话可以选择这些行,但不能更改或删除这些行,直到该语句的事务被commit语句或rollback语句结束为止。 

    因为FOR   UPDATE子句获得了锁,所以COMMIT将释放这些锁。当锁释放了,该游标就无效了。 

    就是这些区别了
     
     摘自: http://hi.baidu.com/yiyfrhwzrdbrtyd/item/4f1bc04f74c1f20ae8350483
  • 相关阅读:
    温故知新 将Date和String类型相互转换
    温故知新 线程
    温故知新 数组
    温故知新 集合
    温故知新 流(字节流与字符流)
    温故知新 jdbc 数据库调取封装
    Reds 持久化 高并发 高可用
    批量修改文件后缀名
    scala之旅-核心语言特性【高阶函数】(十)
    scala之旅-核心语言特性【使用混入组合类】(九)
  • 原文地址:https://www.cnblogs.com/kenwong/p/3600750.html
Copyright © 2011-2022 走看看