使用dbms_logmnr查看日志文件

本文介绍如何通过在线重做日志和DBMS_LOGMNR程序来查找被修改的数据,包括添加日志文件、启动日志分析、查询更新或插入特定列的日志记录等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大多为了寻找被意外修改的数据或者那条sql修改了哪些数据

如果是在线重做日志的话需要该日志是inactive模式下的

查询v$log和v$logfile获取相关信息

执行exec dbms_logmnr.add_logfile('log_filename',dbms_logmnr.new);
其中的日志可以是在线的也可以是离线的归档日志

exec dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);


然后select sql_redo from v$logmnr_contents where owner=user and operation='UPDATE';


如果要查询更新或者插入的某列的特定值可以使用mine_value功能

select sql_redo from v$logmnr_contents where owner=user and operation='UPDATE' and dbms_logmnr.mine_value(redo_value,'SCOTT.T.C1')=1
查询更新scott.t表日志记录c1列为1的日志记录


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值