• ORACLE里锁的几种模式


    ORACLE里锁有以下几种模式:
      
      0:none
      1:null 空
      2:Row-S 行共享(RS):共享表锁
      3:Row-X 行专用(RX):用于行的修改
      4:Share 共享锁(S):阻止其他DML操作
      5:S/Row-X 共享行专用(SRX):阻止其他事务操作
      6:exclusive 专用(X):独立访问使用
      
      数字越大锁级别越高, 影响的操作越多。
      一般的查询语句如select ... from ... ;是小于2的锁, 有时会在v$locked_object出现。
      
      select ... from ... for update; 是2的锁。
      
      当对话使用for update子串打开一个游标时,
      所有返回集中的数据行都将处于行级(Row-X)独占式锁定,
      其他对象只能查询这些数据行,不能进行update、delete或select...for update操作。
      
      insert / update / delete ... ; 是3的锁。
      
      没有commit之前插入同样的一条记录会没有反应,
      因为后一个3的锁会一直等待上一个3的锁, 我们必须释放掉上一个才能继续工作。
      
      创建索引的时候也会产生3,4级别的锁。
      
      locked_mode为2,3,4不影响DML(insert,delete,update,select)操作,
      但DDL(alter,drop等)操作会提示ora-00054错误。
      
      有主外键约束时 update / delete ... ; 可能会产生4,5的锁。
      
      DDL语句时是6的锁。

  • 相关阅读:
    线段树时间分治
    CDQ分治
    并查集练习
    hihocoder 1513 小Hi的烦恼 (bitset优化)
    线段树维护哈希
    使用swift语言进行IOS应用开发
    用jquery+Asp.Net实现省市二级联动
    苹果IOS与谷歌 android系统的UI设计原则
    优秀设计师应当知道的20大UI设计原则
    JQuery Easy Ui dataGrid 数据表格
  • 原文地址:https://www.cnblogs.com/BetterWF/p/2693918.html
Copyright © 2020-2023  润新知