在清除AUDIT的时候,为了避免一次完全清理导致的性能问题,可以设置批量清除的数量:

SQL> SELECT * FROM V$VERSION;

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production

SQL> BEGIN
  2  DBMS_AUDIT_MGMT.SET_AUDIT_TRAIL_PROPERTY(
  3  DBMS_AUDIT_MGMT.AUDIT_TRAIL_AUD_STD, 
  4  DBMS_AUDIT_MGMT.DB_DELETE_BATCH_SIZE, 
  5  200);
  6  END;
  7  /

PL/SQL 过程已成功完成。

上面的例子将自动删除作业中每次删除的数据量设置为200

关于自动删除JOB的建立,可以参考上面的Oracle11gr2 AUDIT清除功能增强(二)这篇文章。

除了自动删除以外,还可以通过命令手工清除AUD$记录:

SQL> SELECT COUNT(*) FROM AUD$;

  COUNT(*)
----------
      1296

SQL> BEGIN
  2  DBMS_AUDIT_MGMT.CLEAN_AUDIT_TRAIL(    
  3  DBMS_AUDIT_MGMT.AUDIT_TRAIL_AUD_STD, 
  4  FALSE);
  5  END;
  6  /

PL/SQL 过程已成功完成。

SQL> SELECT COUNT(*) FROM AUD$;

  COUNT(*)
----------
         0

除了调用DBMS_AUDIT_MGMT包之外,Oracle还直接直接删除AUD$的记录,这种方法一般用在指定查询条件的删除上。

此外如果AUD$表扩展的很大,要在删除记录的同时回收空间,也可以直接对AUD$表执行TRUNCATE操作:

SQL> TRUNCATE TABLE AUD$;

表被截断。

 



扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄