oracle数据库下insert产生rowlockcontention事件记录
程序员文章站
2022-06-21 22:29:48
案例描述
今天在进行RAC 数据库监控时,发现大量的活动会话数,深入调查后,竟然发现是由于insert 语句造成成的阻塞,等待事件为enq tx-row lock content...
案例描述
今天在进行RAC 数据库监控时,发现大量的活动会话数,深入调查后,竟然发现是由于insert 语句造成成的阻塞,等待事件为enq tx-row lock contention
问题定义
为什么insert 语句也会产生row lock contention等待?
分析
收集数据
网络案例收集,在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 参考网址: https://www.killdb.com/2015/07/13/关于enq-tx-row-lock-contention的测试和案例分析.html
分析数据
所收集的案例已经充分说明原因。无需再次分析。结论
当数据表具有唯一索引时,当两个会话一前(未commit)一后插入同样的数据后,就会出现阻塞,表现的等待事件就是row lock contention上一篇: 肺气肿怎么调养比较好
下一篇: 什么是婴儿湿疹 婴儿湿疹怎么办