最近,在我们开发库要对一套实例做一个DDL审计触发器,触发器代码如下所示:
---- 存储DDL语句的表         
create table audit_ddl
(
opertime timestamp PRIMARY KEY,
ip varchar2(20),
hostname varchar2(30),
operation varchar2(30),
object_type varchar2(30),
object_name varchar2(30),
sql_stmt clob,
db_schema varchar2(30)
);
---- 捕获DDL语句的触发器
create or replace trigger trg_audit_ddl
  after create or drop or truncate ON DATABASE
DECLARE
  PRAGMA AUTONOMOUS_TRANSACTION;
  n        NUMBER;
  stmt     clob := NULL;
  sql_text ora_name_list_t;
BEGIN
  n := ora_sql_txt(sql_text);
  FOR i IN 1 .. n LOOP
    stmt := stmt || sql_text(i);
  END LOOP;
  INSERT INTO audit_ddl
    (opertime, ip, hostname, operation, object_type, object_name, sql_stmt,db_schema)
  VALUES
    (systimestamp,
     sys_context('userenv', 'ip_address'),
     sys_context('userenv', 'terminal'),
     ora_sysevent,
     ora_dict_obj_type,
     ora_dict_obj_name,
     stmt,
     user
   );
  COMMIT;
END;

/
 创建审计DDL的触发器成功,并且是生效的,如图:

 但是,我用测试用户创建表、删除表、truncate表,都无法审计到,过程如下:
--具有或非DBA权限用户,执行建表
create table trg_ddl_test as select * from dba_data_files;
--然后用sys或创建ddl审计的用户,查询DDL审计表,无记录返回
[oracle@oradbs ~]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.3.0 Production on Thu May 19 19:31:16 2016
Copyright (c) 1982, 2011, Oracle.  All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL> select * from audit_ddl;
no rows selected
SQL> 
  但是,相同的触发器在相同服务器,相同版本的其他数据库实例上执行,都能捕获到DDL,如图所示:

 后来,对DDL审计触发器做了修改,就是创建测试表,触发触发器,让触发器向DDL审计触发器插入一个1,没有成功;由此,怀疑,DDL审计触发器不起作用的数据库实例参数配置肯定有问题,通过对比发现:隐藏参数_system_trig_enabled在DDL审计触发器不起作用的服务器上被设置为了false:
SQL> show parameter _system_trig_enabled
NAME                              TYPE    VALUE
------------------------------------ ----------- ------------------------------
_system_trig_enabled     boolean    FALSE
 该参数是动态参数,执行alter system set "_system_trig_enabled"=true; 将参数设置为true
SQL> alter system set "_system_trig_enabled"=true; 
System altered.
SQL> show parameter _system_trig_enabled
NAME                             TYPE      VALUE
------------------------------------ ----------- ------------------------------
_system_trig_enabled        boolean  TRUE
 设置完隐藏参数为true后,数据库实例可以正常审计数据库级别的DDL:
--test用户truncate表,drop表
SQL> select * from tab;
TNAME       TABTYPE CLUSTERID
------------------------------ ------- ----------
CDBA_DATA_FILES       TABLE
TRG_DDL_TEST       TABLE
SQL> truncate table TRG_DDL_TEST;
Table truncated.
SQL> drop table TRG_DDL_TEST;
Table dropped.
--DDL审计用户查询审计记录:

 需要注意的这里只审计了create、drop和truncate,如果需要审计所有DDL,只需要修改:after create or drop or truncate on database为after ddl on database即可。

ORACLE数据库DDL审计触发器与隐藏参数_system_trig_enabled相关推荐

  1. Oracle数据库 —— DDL

    时间:2016-10-5 14:55 逆风的方向 更适合飞翔 我不怕千万人阻挡 只怕自己投降 --------------------------------------- 一.表的创建与管理 1.表 ...

  2. oracle数据库登录失败触发器,oracle数据库登录、DDL触发器的应用

    登录触发器 oracle登录记录触发器: 1.创建日志记录表: CREATE TABLE SYSTEM.LOGIN_LOG ( SESSION_ID NUMBER, LOGIN_ON_TIME DAT ...

  3. oracle数据库登录审计,oracle数据库审计

    一.何谓数据库审计? 数据库审计,就是对数据库的活动做跟踪记录,主要包括数据库连接,SQL语句执行,数据库对象访问这些方面的跟踪记录. 二.审记记录的存储方式 分为两种:一种是存储在操作系统文件中,一 ...

  4. Oracle数据库之审计(五)

    目录 1.审计 2.登录审计 3.操作审计 4.对象审计 5.权限审计 Oracle学习的相关知识点(汇总) 1.审计 审计是监视和记录所选用户的数据活动,通常用于调查可疑活动,以及监视与收集特定数据 ...

  5. oracle建个触发器,oracle数据库如何创建触发器实例

    Oracle DBA Studio 工具里面就能创建触发器 CREATE TRIGGER 名称 CREATE TRIGGER - 创建一个新触发器 语法 CREATE TRIGGER name { B ...

  6. oracle数据库userenv,Oracle数据库中userenv、sys_context的参数

    1. USERENV(OPTION) 返回当前的会话信息. OPTION= 1. USERENV(OPTION) 返回当前的会话信息. OPTION='ISDBA'若当前是DBA角色,则为TRUE,否 ...

  7. 达梦数据库或者oracle数据库报错: 超过最大参数个数(32767)

    Oracle 批量插入list 有最大参数限制,需要分批插入处理 private void saveAndUpdate(ArrayList<ServeRecord> insertList) ...

  8. oracle创建dml触发器,Oracle数据库创建DML触发器

    触发器的基本分类 1.行触发器:数据库表中的每一行有变化都会触发一次触发器代码 2.语句触发器:与语句所影响的行数无关,仅触发一次 3.BEFORE触发器:在DML语句执行之前触发 4.ALFTER触 ...

  9. oracle的clob赋值_oracle 存储过程clob参数

    .Net处理Oracle中Clob类型字段总结 最近在做项目中用到Clob这个字段,Clob是存储无限长字符的Oracle字段,用的时候网上找资料找了好久,内容不是很多,大部分都不能用,当然也有可以用 ...

最新文章

  1. 单片机一个月能入门么?单片机工程师能干到多少岁?
  2. 直流稳压电源的输出特性有哪些
  3. Elasticsearch Top 51 重中之重面试题及答案
  4. 第七章 oracle的服务启动顺序、认证方式、
  5. pos机未能连接服务器,pos 机链接不了服务器
  6. python莫比乌斯内接矩形_莫比乌斯反演例题集 ^_^(示例代码)
  7. nginx location正则匹配规则
  8. RC电路 微分器 积分器 滤波器
  9. 微信公众号的图片引用
  10. 无需更改注册表 实现CHM文件从共享文件中直接打开
  11. 简单命令行创建ReactApp
  12. 华为模拟器eNSP练习题 - Hybrid
  13. Java最牛教材!javaexcel合并单元格样式
  14. 基于java spring框架开发部标1078视频监控平台精华文章索引
  15. 微型计算机与接口技术答案,微机原理及接口技术-习题答案
  16. flv怎么转换成mp4?这3种方法总有适合你的
  17. 计算机课程考试质量分析,研究生课程成绩定量评价与质量分析的计算机实现
  18. 深度学习平台——PaddleCloud简介
  19. wps面试一小时的面经
  20. 2014校赛 猫和老鼠

热门文章

  1. JAVA深复制(深克隆)与浅复制(浅克隆)
  2. 第一次加入博客那,鼓励一下自己先
  3. 【python】类的封装、多态
  4. 【python】列表的定义与操作
  5. 接口测试之post常见数据提交方式
  6. 测试老司机一起聊聊性能测试是怎么一回事?
  7. 测试人员提高业务掌握度的方案
  8. python可以调试吗_python调试的几种方法
  9. 时间序列分析(6)| DF检验
  10. 客户端序列码生成_Django REST Framework教程(2): 序列化器介绍及开发基于函数视图的API...