您现在的位置是:首页 >

哪种锁最好 关于Oracle几种锁管理的汇总

火烧 2022-05-16 00:59:08 1048
关于Oracle几种锁管理的汇总 ORACLE里锁有以下几种模式: o e ull 空 Row S 行共享 RS 共享表锁 u hare Row X 行独占 RX 用于行的修改 u exclu ive

关于Oracle几种锁管理的汇总  

哪种锁最好 关于Oracle几种锁管理的汇总
ORACLE里锁有以下几种模式:    none    null 空    Row S 行共享(RS) 共享表锁 sub share     Row X 行独占(RX) 用于行的修改 sub exclusive     Share 共享锁(S) 阻止其他DML操作 share    S/Row X 共享行独占(SRX) 阻止其他事务操作 share/sub exclusive     exclusive 独占(X) 独立访问使用 exclusive        数字越大锁级别越高 影响的操作越多         级锁有 Select 有时会在v$locked_object出现     级锁有 Select for update Lock For Update Lock Row Share     select for update当对话使用for update子串打开一个游标时 所有返回集中的数据行都将处于行级(Row X)独占式锁定 其他对象只能查询这些数据行 不能进行update delete或select for update操作     级锁有 Insert Update Delete Lock Row Exclusive    没有mit之前插入同样的一条记录会没有反应 因为后一个 的锁会一直等待上一个 的锁 我们必须释放掉上一个才能继续工作     级锁有 Create Index Lock Share    locked_mode为 不影响DML(insert delete update select)操作 但DDL(alter drop等)操作会提示ora 错误     resource busy and acquire with NOWAIT specified     // *Cause: Resource interested is busy     // *Action: Retry if necessary     级锁有 Lock Share Row Exclusive     具体来讲有主外键约束时update / delete ; 可能会产生 的锁     级锁有 Alter table Drop table Drop Index Truncate table Lock Exclusive        以DBA角色 查看当前数据库里锁的情况可以用如下SQL语句     如果有长期出现的一列 可能是没有释放的锁 我们可以用下面SQL语句杀掉长期没有释放非正常的锁         alter system kill session sid serial# ;        如果出现了锁的问题 某个DML操作可能等待很久没有反应         当你采用的是直接连接数据库的方式 也不要用OS系统命令 $kill process_num 或者 $kill process_num来终止用户连接 因为一个用户进程可能产生一个以上的锁 杀OS进程并不能彻底清除锁的问题 lishixinzhi/Article/program/Oracle/201311/18456  
永远跟党走
  • 如果你觉得本站很棒,可以通过扫码支付打赏哦!

    • 微信收款码
    • 支付宝收款码