首页 数据库 mysql教程 使用logminer分析oracle日志

使用logminer分析oracle日志

Jun 07, 2016 pm 02:56 PM
oracle 使用 分析 我们 日志

当我们不小心误操作致使数据库数据丢失、改变时, 需要对数据库对象做基于时间点的恢复,找到我们需要的数据,这个时间点不能认为精确确定,我们可以通过对oracle日志进行分析,而获得无操作的精确时间点。 oracle db提供了一个分析日志包logmnr logminer 工

当我们不小心误操作致使数据库数据丢失、改变时, 需要对数据库对象做基于时间点的恢复,找到我们需要的数据,这个时间点不能认为精确确定,我们可以通过对oracle日志进行分析,而获得无操作的精确时间点。

oracle db提供了一个分析日志包logmnr

logminer 工具的使用
     -------对redo log 进行挖掘,找出在某个时间点所作的DDL 或DML 操作(包括:时间点、datablock scn 、sql语句)

实验测试

SQL> select name from v$archived_log;

NAME
--------------------------------------------------
/oracle/arch1/1_2_883536782.dbf

SQL>
SQL>
SQL> delete from scott.t1;

576 rows deleted.

SQL> alter system archive log current;

System altered.

SQL> create table scott.t6 as select * from scott.emp;

Table created.

SQL> alter system archive log current;

System altered.

SQL> select name from v$archived_log;

NAME
--------------------------------------------------
/oracle/arch1/1_2_883536782.dbf
/oracle/arch1/1_3_883536782.dbf
/oracle/arch1/1_4_883536782.dbf
登录后复制

--启动log miner添加要分析的日志

SQL> execute dbms_logmnr.add_logfile(logfilename=>'/oracle/arch1/1_2_883536782.dbf',options=>dbms_logmnr.new);

PL/SQL procedure successfully completed.
登录后复制

--添加需要分析的日志

SQL> execute dbms_logmnr.add_logfile(logfilename=>'/oracle/arch1/1_3_883536782.dbf',options=>dbms_logmnr.addfile);

PL/SQL procedure successfully completed.

SQL> execute dbms_logmnr.add_logfile(logfilename=>'/oracle/arch1/1_4_883536782.dbf',options=>dbms_logmnr.addfile)

PL/SQL procedure successfully completed.
登录后复制

--执行log miner

SQL> execute dbms_logmnr.start_logmnr(options=>dbms_logmnr.dict_from_online_catalog);

PL/SQL procedure successfully completed.
登录后复制

--查询分析结果

SQL> alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss';

Session altered.
SQL> select username,scn,timestamp,sql_redo from v$logmnr_contents where seg_name='T1'; 
USERNAME                              SCN TIMESTAMP
------------------------------ ---------- -------------------
SQL_REDO
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
delete from "SCOTT"."T1" where "EMPNO" = '7782' and "ENAME" = 'CLARK' and "JOB" = 'MANAGER' and "MGR" = '7839' and "HIREDATE" = TO_DATE('1981-06-09 00:00:00', 'yyyy-mm-dd hh24:mi:ss') and "SAL" = '245
0' and "COMM" IS NULL and "DEPTNO" = '10' and ROWID = 'AAAVbSAAFAAAACXABi';

SYS                               1494545 2015-06-28 04:24:44
delete from "SCOTT"."T1" where "EMPNO" = '7839' and "ENAME" = 'KING' and "JOB" = 'PRESIDENT' and "MGR" IS NULL and "HIREDATE" = TO_DATE('1981-11-17 00:00:00', 'yyyy-mm-dd hh24:mi:ss') and "SAL" = '500
0' and "COMM" IS NULL and "DEPTNO" = '10' and ROWID = 'AAAVbSAAFAAAACXABj';

SYS                               1494545 2015-06-28 04:24:44
delete from "SCOTT"."T1" where "EMPNO" = '7844' and "ENAME" = 'TURNER' and "JOB" = 'SALESMAN' and "MGR" = '7698' and "HIREDATE" = TO_DATE('1981-09-08 00:00:00', 'yyyy-mm-dd hh24:mi:ss') and "SAL" = '1
。。。。。
登录后复制


--结束log miner 分析

SQL> execute dbms_logmnr.end_logmnr;

PL/SQL procedure successfully completed.
登录后复制


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle rac新增、替换硬盘的操作方法 oracle rac新增、替换硬盘的操作方法 Apr 11, 2025 pm 05:39 PM

Oracle RAC 硬盘新增和替换操作:新增硬盘:添加新磁盘、创建 ASM 磁盘组、添加到集群、移动数据文件。替换硬盘:识别故障硬盘、关闭磁盘组、更换硬盘、重新打开磁盘组、修复故障磁盘、移动数据文件。

oracle的数据库由哪些类型文件组成 oracle的数据库由哪些类型文件组成 Apr 11, 2025 pm 04:18 PM

Oracle数据库文件系统由多种文件共同构成:数据文件:存储实际数据。控制文件:记录数据库结构信息。重做日志文件:记录数据库修改操作。参数文件:包含数据库参数设置。临时文件:存储中间结果。理解这些文件类型及其之间的关系对于数据库管理和性能调优至关重要。规划文件数量、大小和存储介质可优化性能并确保数据可用性。

oracle数据库在c盘安装了哪些东西 oracle数据库在c盘安装了哪些东西 Apr 11, 2025 pm 04:21 PM

Oracle数据库在C盘的藏身之处:注册表:使用注册表编辑器搜索"Oracle",可找到包括安装路径、服务名称等信息。文件系统:Oracle文件散布在C盘多个位置,包括主目录、系统文件、临时文件等。环境变量:Oracle设置的环境变量(如ORACLE_HOME、ORACLE_SID)指向安装目录和实例名称。谨慎操作:卸载Oracle时,不仅要删除文件,还需清理注册表和服务,建议使用官方卸载工具或寻求专业帮助。空间管理:优化磁盘空间,避免将Oracle安装在C盘;定期清理临时文

oracle数据库基础知识总结 oracle数据库基础知识总结 Apr 11, 2025 pm 06:33 PM

Oracle 数据库是一款可靠、可扩展且功能丰富的关系型数据库管理系统(RDBMS)。其架构遵循客户端-服务器模型,包含服务器端组件(Oracle Net)、实例、共享内存区域(SGA)和后台进程,以及存储数据的数据库文件。基本概念包括表、行、列、主键、外键、索引和游标。该数据库以其高可用性、大数据支持、丰富的功能、安全性强和易用性等优势而著称。

oracle乱码如何处理 oracle乱码如何处理 Apr 11, 2025 pm 07:00 PM

Oracle 乱码问题通常由字符集设置不当引起。解决方法包括:检查服务器、数据库和客户机字符集。根据需要设置服务器、数据库和客户机字符集。使用 CONVERT 函数或 DBMS_LOB.CONVERT_LOB 函数修复乱码数据。始终指定字符集并正确设置 NLS 参数。

oracle如何去重查询 oracle如何去重查询 Apr 11, 2025 pm 07:33 PM

Oracle 提供多种去重查询方法:DISTINCT 关键字返回每列的唯一值。GROUP BY 子句对结果分组并返回每个分组的非重复值。UNIQUE 关键字用于创建仅包含唯一行的索引,查询该索引将自动去重。ROW_NUMBER() 函数分配唯一数字并过滤出仅包含第 1 行的结果。MIN() 或 MAX() 函数可返回数字列的非重复值。INTERSECT 运算符返回两个结果集的公共值(无重复项)。

oracle数据库需要开启哪些服务器 oracle数据库需要开启哪些服务器 Apr 11, 2025 pm 04:12 PM

启动Oracle数据库实例的必要组件包括:操作系统内核、Oracle数据库监听器、Oracle数据库实例进程和相关后台进程。这些组件的启动方法包括:启动监听器(例如:lsnrctl start)、连接数据库(例如:sqlplus / as sysdba)和启动数据库实例(例如:startup)。常见问题包括监听器或实例启动失败,调试方法包括检查配置文件或数据库日志文件。优化建议包括分配充足资源、调整参数和定期备份。

如何修改oracle字符集 如何修改oracle字符集 Apr 11, 2025 pm 06:57 PM

要修改 Oracle 字符集,需要:备份数据库;在 init.ora 文件中修改字符集设置;重新启动数据库;修改现有表和列以使用新字符集;重新加载数据;修改数据库链接(可选)。

See all articles