在oracle中,可以利用select语句配合“v$recovery_file_dest”查询oracle归档日志,select语句用于从数据库中选取数据,语法为“select * from v$recovery_file_dest”。
本教程操作环境:Windows10系统、Oracle 11g版、Dell G3电脑。
查看归档日志大小及使用情况
select * from v$recovery_file_dest
示例如下:
SQL> select * from v$recovery_file_dest; NAME -------------------------------------------------------------------------------- SPACE_LIMIT SPACE_USED SPACE_RECLAIMABLE NUMBER_OF_FILES ----------- ---------- ----------------- --------------- /u03/fast_recovery_area 8589934592 6551817216 SQL> select * from v$flash_recovery_area_usage; FILE_TYPE PERCENT_SPACE_USED PERCENT_SPACE_RECLAIMABLE -------------------- ------------------ ------------------------- NUMBER_OF_FILES --------------- CONTROL FILE 0 0 0 REDO LOG 1.83 0 3 ARCHIVED LOG 74.44 0 159
如果 ARCHIVED LOG 超过90% oracle随时有宕机的危险
增大归档日志空间
SQL> alter system set db_recovery_file_dest_size=20G; System altered.
删除归档日志
1.看看现在用了多少归档日志了(按百分比):
select * from v$flash_recovery_area_usage;
如果超过90%随时有宕机的危险
2.当删除归档文件后需要用RMAN工具释放归档所占用的空间,首先连接RMAN工具
rman target sys/pass
3.查查归档日志吧
crosscheck archivelog all;
4.觉着没用就干掉它吧,如果想保留今天的用下面那个语句
delete expired archivelog all;(全部删除) delete archivelog until time 'sysdate - 1';(保留当天删除,删除之前所有)
也可以:$ORACLE_BASE/flash_recovery_area/你的实例名/archivelog/这个路径下,找到归档日志文件,把没用的删了
推荐教程:《Oracle视频教程》
以上是怎么查询oracle归档日志的详细内容。更多信息请关注PHP中文网其他相关文章!