当前位置: 移动技术网 > IT编程>数据库>Oracle > oracle数据库下insert产生rowlockcontention事件记录

oracle数据库下insert产生rowlockcontention事件记录

2018年03月02日  | 移动技术网IT编程  | 我要评论

案例描述

今天在进行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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网