当前位置:  数据库>oracle

DML操作 DDL触发器

    来源: 互联网  发布时间:2017-06-07

    本文导语: 今天应用方告诉我,一个DML操作导致数据库报错,说“ORA-234567,不允许开发执行DDL操作,请联系DBA” 为了安全,DBA在各个库上建立了DDL触发器,不允许开发人员执行DDL。 但是开发人员给我反馈,他们仅仅只是执行了普通的INSERT...

今天应用方告诉我,一个DML操作导致数据库报错,说“ORA-234567,不允许开发执行DDL操作,请联系DBA”

为了安全,DBA在各个库上建立了DDL触发器,不允许开发人员执行DDL。

但是开发人员给我反馈,他们仅仅只是执行了普通的INSERT操作,没有任何DDL操作。

第一个感觉是,可能DML操作导致数据库递归了执行了某些DDL操作。

还好这个错误可以重现,经过10046跟踪。发现由于在执行INSERT过程中,数据库的表空间不足,导致Oracle递归了进行清空回收站的操作,这个操作属于DDL。因此就出现了开头说的问题。

当然在一个监控良好的生产环境并不会出现这个问题,在表空间不够的时候,应该结合监控系统第一时间报警出来。

但是经过测试发现,已经删除的表的空间会计算进入表空间剩余空间

如果回收站打开的话,即使系统看上去还有几十G的剩余,但是可能这些空间都是被删除的表的空间,需要清空回收站才能使用。

如果系统里存在DDL TRIGGER,那么就可能会导致,明明系统里还有大量的可用空间,但是INSERT却报错“ORA-234567,不允许开发执行DDL操作,请联系DBA”

开不开回收站是个问题。

Oracle DML流程

PL/SQL“ ORA-14551: 无法在查询中执行 DML 操作”解决

MySQL常用DDL、DML、DCL语言整理(附样例)

Oracle基本事务和ForAll执行批量DML练习

Oracle DML语句(insert,update,delete) 回滚开销估算


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Sql学习第二天——SQL DML与CTE概述
  • Oracle DDL,DML,DCL,TCL 基础概念
  • Oracle10g使用sql获得ADDM报告以及利用ADDM监控表的dml情况
  • T-SQL入门教程之获取DML语句信息
  • DDL、DML和DCL的区别与理解


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,