在Oracle10g中如何删除归档日志

    技术2025-04-29  23

    今天一个朋友问我在Oracle10g中如何删除归档日志,就这个问题作如下回答:

     

    Oracle中归档日志不能通过操作系统(OS)级命令直接删除,因为归档日志的一些信息在控制文件中是有记录的,而且如果使用OS级命令直接删除以后,控制文件中的信息是不会改变的,还有,就是相关系统视图中的信息也不会发生改变。Oracle系统仍然会认为归档日志是存在的。

    那怎么正确的删除归档日志呢?

     

    可以使用下面的几种方法:

     

    可以使用RMAN来删除archivelog,具体可以按以下步骤操作:     1、使用OS级命令物理删除archivelog    2、进入RMAN    3、crosscheck archivelog all;    4、delete expried archivelog all;     这样就在一些Oracle的记录中查不到相应的archivelog记录了。  二、直接使用RMAN删除archivelog     其实在RMAN中是可以使用命令直接将ARCHIVELOG删除的,命令如下:     RMAN>DELETE ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7';     表示删除7天以前的所有archivelog,但是这个命令的缺点是无法对archivelog进行细致的划分。  三、使用RMAN备份aechivelog后删除     这是一种最为稳妥的方法了,使用RMAN备份archivelog,备份后全部删除     backup format '/u01/arch_%T_%s_%U' archivelog all delete input;    或者    backup database plus archivelog;

     

    最新回复(0)