DML操作 DDL触发器
今天应用方告诉我,一个DML操作导致数据库报错,说“ORA-234567,不允许开发执行DDL操作,请联系DBA”
为了安全,DBA在各个库上建立了DDL触发器,不允许开发人员执行DDL。
但是开发人员给我反馈,他们仅仅只是执行了普通的INSERT操作,没有任何DDL操作。
第一个感觉是,可能DML操作导致数据库递归了执行了某些DDL操作。
还好这个错误可以重现,经过10046跟踪。发现由于在执行INSERT过程中,数据库的表空间不足,导致Oracle递归了进行清空回收站的操作,这个操作属于DDL。因此就出现了开头说的问题。
当然在一个监控良好的生产环境并不会出现这个问题,在表空间不够的时候,应该结合监控系统第一时间报警出来。
但是经过测试发现,已经删除的表的空间会计算进入表空间剩余空间
如果回收站打开的话,即使系统看上去还有几十G的剩余,但是可能这些空间都是被删除的表的空间,需要清空回收站才能使用。
如果系统里存在DDL TRIGGER,那么就可能会导致,明明系统里还有大量的可用空间,但是INSERT却报错“ORA-234567,不允许开发执行DDL操作,请联系DBA”
开不开回收站是个问题。
相关推荐
昊 2020-06-16
daillo 2020-04-07
applex 2019-12-29
zhaojp0 2019-12-11
xzero 2019-12-08
talkingDB 2019-12-02
zjuwangleicn 2020-06-25
debugjoker 2020-06-17
sunnyxuebuhui 2020-06-14
hanshangzhi 2020-06-14
ncomoon 2020-06-14
hanshangzhi 2020-06-12
wudaokouer 2020-04-16
一昕之代码 2020-02-20
李轮清 2020-05-11
URML 2020-05-10
nimeijian 2020-05-06
lpfvip00 2020-04-26