renran421 发表于 2018-9-24 09:16:22

ORACLE 锁表问题

  一般的查询语句如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的锁。
  以DBA角色, 查看当前数据库里锁的情况可以用如下SQL语句:

页: [1]
查看完整版本: ORACLE 锁表问题