第3章 Oracle性能问题汇总-3.4 触发器引发的问题

在这里插入图片描述

环境说明:

DB:Oracle 12.2.0.1.0
OS:Redhat 6.8

问题现象 :

谓词通过唯一性索引,更新一条记录,耗时很长;
通过 AWR查看TOP SQL,这个UPDATE SQL语句逻辑读,物理读等都非常高;
初步怀疑执行计划出现变化, 例如index unique scan变成 table access full ,但是通过 DBA_HIST_SQL_PLAN发现近期执行计划并没有改变;
通过10046查看SQL执行计划,显示这个更新语句耗时,逻辑读,物理读等都非常低;

问题原因 :

触发器导致的;
更新语句 A 执行前,触发了 trigger B,其中trigger B 内部执行较慢,导致A一直在等待;
由于 trigger B 执行过程中占用大量的资源,在AWR中会将trigger消耗的资源也加到update语句上,有时可能会干扰问题诊断;

问题结论:

当发现某个语句执行突然变慢了,执行时间,逻辑读,物理读等突然飙升,
在排查数据量,执行计划等都没有异常,可以查看是否存在不合理的触发器;

问题重现举例 :

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值