Oracle删除归档日志

Oracle删除归档日志

1.运行环境

 操作系统:Windows Server 2019

 Oracle版本:11gr2,即11.2

2.检查数据库的归档配置

 打开CMD或POWERSHELL(win键+R键后输入对应名称):

如果控制台乱码,输入"CHCP 65001"命令可以适配当前字符集。

bash 复制代码
CHCP 65001

登录数据库:

bash 复制代码
sqlplus / as sysdba

查看是否开启归档日志:

bash 复制代码
archive log list;

可以看到,在磁盘下有这些归档文件:

3.使用RMAN删除归档文件

用CMD打开Oracle目录下的rman程序。

首先找到rman程序的物理路径:

一般都在这个路径下:D:\ORACLE\product\11.2.0\dbhome_1\BIN

在CMD中进入该程序的文件夹,并打开程序:

注:先用exit命令退出sqlplus程序,然后使用cd命令进入文件夹,最后输入exe程序名打开程序

bash 复制代码
exit
cd D:\ORACLE\product\11.2.0\dbhome_1\BIN
rman.exe

连接当前数据库:

bash 复制代码
connect target /

使用命令删除归档日志文件:delete archivelog 什么什么

注:此命令将永久删除归档文件

  1. 删除7天前的归档日志文件:
bash 复制代码
delete archivelog until time 'sysdate-7';

可能出现的问题:

1.没有需要删除的文件:

2.状态不匹配:该错误请到下一个标题中进行查看(4.归档状态不匹配)

如图为删除成功:

4.归档状态不匹配

bash 复制代码
是否确定要删除以上对象 (输入 YES 或 NO)? yes

RMAN-06207: 警告: 由于状态不匹配, 所以不能删除 1 对象 (对于 DISK 通道)。
RMAN-06208: 请用 CROSSCHECK 命令修正状态
RMAN-06210: 不匹配对象的列表
RMAN-06211: ==========================
RMAN-06212: 对象类型   文件名/句柄
RMAN-06213: --------------- ---------------------------------------------------
RMAN-06214: Archivelog      D:\ORACLE\FAST_RECOVERY_AREA\ORCL\ARCHIVELOG\1_31682_1098628977.ARC

  如上错误是因为,直接在Windows的文件管理器中进行删除了,但oracle却不知道这个文件删除了,导致报错。这个错误也比较好恢复。其实在日常维护中,我们也可以直接删除归档文件,只要不是最新的日期就行。

在RMAN中输入以下命令:

1.检查磁盘所有归档日志文件是否存在:

bash 复制代码
crosscheck archivelog all;

2.删除不存在(过期)的归档日志记录信息:

bash 复制代码
delete expired archivelog all;

如图所示删除成功,此时归档日志文件已经完整,可以进行下一步的删除。

参考:
Oracle 11g 管理归档日志
如何正确删除ORACLE归档日志文件

相关推荐
我是一颗柠檬6 小时前
【MySQL全面教学】MySQL面试高频考点汇总Day15(2026年)
数据库·后端·mysql·面试
凯瑟琳.奥古斯特7 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
身如柳絮随风扬7 小时前
数据库读写分离:从原理到实战,构建高并发系统
数据库·mysql
提笔了无痕8 小时前
RAG存储策略中.md格式的切片与存储怎么处理
数据库·ai·rag
yaoxin5211238 小时前
419. 现代 Java IO 最佳实践 - 写入文本文件
java·windows·python
陳土8 小时前
DuckDB精读——基于Getting started with DuckDB
数据库·oracle
凯瑟琳.奥古斯特8 小时前
数据库原理选择题精选
数据库·python·职场和发展
曹牧9 小时前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
朝阳5819 小时前
MongoDB 副本集从零搭建到生产可用
数据库·mongodb