Oracle审计表AUD$处理方法

半腔热情 提交于 2019-12-03 05:22:06


Oracle版本:11.2.0,其他版本要测试DBMS_AUDIT_MGMT能否成功

1. 查询表,然后truncate

     select count(*) from aud$;

     truncate table aud$;

     select count(*) from aud$;


2.创建表空间

create tablespace adttbs
       datafile '/oracle/OMT/admin/oradata/aud01.dbf'  size 2G autoextend on;

 

SELECT table_name, tablespace_name
 FROM dba_tables
 WHERE table_name IN ('AUD$', 'FGA_LOG$')
 ORDER BY table_name;

 


3.aud$表移动到新tablespace

BEGIN
DBMS_AUDIT_MGMT.SET_AUDIT_TRAIL_LOCATION(audit_trail_type => DBMS_AUDIT_MGMT.AUDIT_TRAIL_DB_STD,
audit_trail_location_value => 'ADTTBS');
END;
/

 

4.sys用户procedure:

create or replace procedure
sp_trunc_audit_log is
begin
   execute immediate
       'truncate table aud$';
end;

授权:
grant execute on sp_trunc_audit_log to system;


5.system用户procedure:

create or replace procedure
sp_job_trunc_audit_log is
begin
    sys.sp_trunc_audit_log;
end;

 

6.自动调度job

BEGIN
  DBMS_SCHEDULER.CREATE_JOB
  (
    job_name   => 'day_trunc_audit_log',
    job_type   => 'STORED_PROCEDURE',
    job_action => 'SP_JOB_TRUNC_AUDIT_LOG',
    start_date => sysdate,
    repeat_interval => 'FREQ=DAILY; BYHOUR=04; BYMINUTE=05;INTERVAL=1',
    enabled         => true,
    comments        => 'every day truncate table audit log'
  );
END;
————————————————
版权声明:本文为CSDN博主「gyanp」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/gyanp/article/details/9273251

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!