在11.2中,Oracle对于AUDIT记录的清除工作进行了增强。
这一篇介绍清除批量设置和手工清除。
Oracle11gr2 AUDIT清除功能增强(一):http://yangtingkun.itpub.net/post/468/496990
Oracle11gr2 AUDIT清除功能增强(二):http://yangtingkun.itpub.net/post/468/498990
在清除AUDIT的时候,为了避免一次完全清理导致的性能问题,可以设置批量清除的数量:
SQL> SELECT * FROM V$VERSION;
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$;
表被截断。