2017-09-29 DBA日记,oracle下insert产生row lock contention事件记录

来源:互联网 发布:excel2016编程 编辑:程序博客网 时间:2024/04/28 05:09

案例描述

今天在进行RAC 数据库监控时,发现大量的活动会话数,深入调查后,竟然发现是由于insert 语句造成成的阻塞,等待事件为enq tx-row lock contention

问题定义

为什么insert 语句也会产生row lock contention等待?

分析

收集数据

  1. 网络案例收集,在asktom的网站上及www.killdb.com上都有文章记录:
    • 假设数据库T1(id,username),具有唯一索引在ID上。
    • 会话1,在10:00 insert (1,'jack') ,但未commit
    • 会话2, 在10:01 insert (1,'jack') ,就会被组塞。
    • 会话3,在10:02 查询v$session,就会发阻塞的等待事件:enq:Tx ROW LOCK CONTENTION 参考网址: http://www.killdb.com/2015/07/13/关于enq-tx-row-lock-contention的测试和案例分析.html

分析数据

  1. 所收集的案例已经充分说明原因。无需再次分析。

结论

  1. 当数据表具有唯一索引时,当两个会话一前(未commit)一后插入同样的数据后,就会出现阻塞,表现的等待事件就是row lock contention
阅读全文
0 0
原创粉丝点击