一、介绍

详细参考:https://blog.csdn.net/jinjazz/article/details/2459692

转自:https://blog.csdn.net/hch271510994/article/details/54091321

Log Explorer主要用于对MSSQLServer的事物分析和数据恢复。你可以浏览日志、导出数据、恢复被修改或者删除的数据(包括执行过update,delete,drop和truncate语句的表格)。一旦由于系统故障或者人为因素导致数据丢失,它能够提供在线快速的数据恢复,最大程度上保证恢复期间的其他事物不间断执行。

他可以支持SQLServer7.0和SQLServer2000,提取标准数据库的日志文件或者备份文件中的信息。

其中提供两个强大的工具:日志分析浏览,对象恢复。具体功能如下:

  • 日志文件浏览
  • 数据库变更审查
  • 计划和授权变更审查
  • 将日志记录导出到文件或者数据库表
  • 实时监控数据库事物
  • 计算并统计负荷
  • 通过有选择性的取消或者重做事物来恢复数据
  • 恢复被截断或者删除表中的数据
  • 运行SQL脚本

二、安装

LogExplore包含两部分:

  • 客户端软件
  • 服务器代理

服务器端代理是保存在SQLServer主机中的一个只读存储过程,他的作用是接受客户端请求,读取在线事物日志块并通过网络传给客户端软件,由客户端软件来读取这些原始的数据块来完成Log Explore所提供的所有功能。

他依赖来的网络协议包括:

  • Named Pipe:局域网中适用
  • Tcp/Ip:广域网中适用

此软件是C/S模式,在MSSQL服务器上安装服务端,客户端可以安装在需要的地方。

三、使用说明

3.1连接数据库

双击Log Explore,出现的软件界面

点击左上框的Attach Log File,进入连接数据库界面

注意:

选择你需要查看的数据库名,以及选择是使用在线的日志还是使用备份的文件进行分析。

成功连接到数据库后,会出现一个警告,按确定。

3.2功能说明

Log Summary:

日志文件的概要信息。

Load Analysis:

列出指定时间范围内的一些事物,用户和表载入的概要信息。

Filter Log Record:

日志过滤设置。支持过滤条件包括:时间、操作类型、表、用户、SPID、搜索深度、Dropped表项以及登录设置和应用程序设置

Browse:

日志浏览,核心模块。

  • View Log功能:
    列表如图,可以用TransID来区分事物并用不同颜色标识。工具栏的按钮是一些基本查询操作。鼠标右键弹出菜单中有Undo Transaction和UndoOperation可以恢复黑色箭头选中的事物或者操作项。
  • Real-Time Monitor:
    实时监控事物日志,通过轮询来实现。可以暂停或者停止监控,可以更改轮询周期。
  • 相关DML语言和DDL语言可以在Row Revision History、Row Transaction History以及View DDL Commands来查询。

Export Log Records:

  • Export to SQL

从日志上导出数据并且恢复到SQL数据库的表里

  • Export to Files

从日志上导出数据,保存为xml、html或者字符分割文件

Recovery: Undo User Transactions :

允许撤销一系列选中的事务,例如:撤销由于用户或者应用错误导致数据的删除或者修改。

Recovery: Redo User Transactions:

允许你重做一系列你选中的事务。

Salvage Dropped/Truncated Data:

允许你恢复部分或者所有的数据,对于一个被删除或者truncate的表

Restore Table from Backup:

使用备份来恢复表数据

Run SQL Script:

允许你执行保存在脚本文件里的SQL命令。

Exit:

退出Log Explorer

四、数据恢复例子

4.1数据误删

如图,模拟数据被误删的情况,测试环境是把test数据库里test表里的2行数据进行删除。

4.2事务查找

通过Log Explorer,查找数据删除操作的事务日志。如图:我们在View Log上看到刚才对于test表的2个DELETE_ROWS的操作,也就是说name列中数据为4和5的2行数据已经被删除。

4.3数据恢复

右键点击要进行恢复操作的事务操作,选择Undo Transaction

然后会出现一个回滚文件的保存框,此文本内容为要进行恢复的SQL语句。

把Recovery1.sql文件的内容拷贝到查询分析器里执行,完成恢复的操作

五、数据库相关介绍

5.1事物日志(Transaction Log)

SQLServer的每个数据库都包含事物日志,它以文件的形式存储,可以记录数据库的任何变化。发生故障时SQLServer就是通过它来保证数据的完整性。

5.2操作(Operation)

操作是数据库中定义的"原子行为",每个操作都在日志文件中保存为一条记录。它可以是用户直接输入的SQL语句,比如标准的insert命令,日志文件中便会记录一条操作代码来标志这个insert操作。

5.3事物(Transaction)

事物是一系列操作组成的序列。他可以理解为直观的不可分割的一笔业务,可以执行成功或者失败。典型的事物比如由应用程序发出的具有开启-提交功能的一组SQL语句。不同的事物靠事物Id号(transaction ID)来区分,具有相同ID的事物记录的日志也相同。

5.4在线事物日志(Online Transaction Log)

在线事物日志是指当前活动数据库所用的日志。可以通过如下命令来确定其对应文件:

Select * from SYSFILES

他的文件后缀名一般是.LDF

5.5离线事物日志(Offline Transaction Log)

离线事物日志是指非活动数据库所用的日志。当其数据库处于关闭(ShutDown)才状态下可以进行复制备份操作。他的结果同在线事物日志完全相同。

5.6备份文件

备份文件是保存食物日志备份的文件,通常管理员通过运行SQL语句或者企业管理器来生成该文件。备份文件的内部结构和事物日志不同,他采用称为MTF的格式来保存数据。一个备份文件可以包含一个日志的多组备份,甚至包括多个数据库的混合备份.

5.7设置为自动收缩

企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"

强烈要求该项不要选中.否则SQLServer将以循环的方式来覆盖先前的日志记录,将会导致LogExplore无法恢复错误.

5.8数据恢复介绍

LogExplore允许你恢复应为误操作或者程序错误而导致的数据丢失或者更改.比如执行update\Delete语句时丢失了where子句,或者错误使用了Dts功能.

LogExplore不支持直接修改数据库.他可以生成事物的逆操作脚本.

如果log是delete table where ...的话,生成的文件代码就是insert table ....

你可以通过SQL查询分析器,或者LogExplore的Run SQL Script功能来执行生成脚本.

5.9关于Undo

Undo功能可以逆操作一组指定的用户事物。包括insert,delete和update,其局限性如下:

  • 事物类别:LogExplore只能undo用户事物。用户事物是指在用户表上定义的事物,不支持系统表的更新恢复。同时,他也不支持计划变更的回滚。
  • Blob类型:包括text,ntext,image类型。LogExplore只支持这些类型的insert和delete恢复,不支持update语句恢复。

5.10关于redo

Redo功能可以再次运行一组指定事物。它可以在以下情况中用到:

丢失数据库而且没有任何备份文件。

  • 如果原始日志文件没有丢失可以通过Redo来实现恢复。
  • 通过完整备份文件来把数据库恢复到某指定时间点,再通过redo功能完整恢复。它可以重放Create Table和Create Index命令,来重新生成被删掉的表,同时也受blob字段的限制。

5.11 SQL逆操作

1、Insert--Delete

2、Delete--Insert

3、Update

Column1

Column2

A

B

事物1

Column1

Column2

X

B

事物2

Column1

Column2

Z

T

你可以只对事物1做逆操作

Column1

Column2

A

T

注意:如果你选中了‘Do not restore column values that have been changed by subsequent modifications‘项,只对事物1逆转将不会产生任何结果。

5.12拯救Dropped/Truncate命令导致的数据丢失

执行Drop Table和Truncate Table命令虽然会被SQLServer记录到日志文件中,但是并不记录被删除的数据。你可以使用LogExplore提供的功能来恢复这些数据。LogExplore提供两种机制来恢复被Drop或者Truncate的数据。

1、如果你有备份文件可以直接通过备份文件恢复。

2、通过LogExplore提供的方法来恢复。

当执行如上命令时,SQLServer会将保存数据的页面放入空闲页面列表中。如果此页没有被再次使用则将一直保存原始数据。恢复时,LogExplore将从空闲页面列表中搜寻没有被再次使用的页面,然后生成一个SQL脚本来从这些页面重组原始数据。LogExplore可以确定被删掉的原始数据行,并在完成时显示原始行数和实际恢复的行数,由此可以断定是否全部恢复

Log Explorer使用说明,布布扣,bubuko.com

Log Explorer使用说明

转载于:https://www.cnblogs.com/gered/p/9797256.html

Log Explorer 恢复误删除、更新数据相关推荐

  1. 用Log Explorer恢复数据的基本操作

    一 如何恢复被delete/update的数据 操作步骤     1 连接到被删除数据库的Db 打开log explorer  选择  "file"->"attac ...

  2. 通过sqlserver日志恢复误删除的数据

    通过sqlserver日志恢复误删除的数据 原文:通过sqlserver日志恢复误删除的数据 如果你已经急的焦头烂额,看到这篇文章的时候,请你换个坐姿,深呼吸几次,静下心来将这篇文章读完,也许你的问题 ...

  3. 使用Log Explorer恢复数据

    SQL code Log Explorer 4.1 For SQL Server 2005 http://www.itpub.net/thread-1018418-1-1.html 用日志工具Log ...

  4. 【转载】通过sqlserver日志恢复误删除的数据

    如果你已经急的焦头烂额,看到这篇文章的时候,请你换个坐姿,深呼吸几次,静下心来将这篇文章读完,也许你的问题迎刃而解. 我遇到的情况是这样的,网站被植入木马,盗取了我的web.config文件,web. ...

  5. db2怎么恢复误删除的数据_DB2误删数据后的恢复方法实践

    1.在源库中使用以下语句生成重定向脚本: db2 "restore db dbname from /yourdbparth taken at timestamp into dbname re ...

  6. 如何利用Flashback Query 恢复误删除的数据

    网上有很多关于数据回复的文章,这里整理一篇供大家参考,希望能帮助的大家! 推荐一家即时通讯云服务商:www.yun2win.com,功能包含im即时通讯.实时音视频.电子白板.屏幕共享的多种融合通讯云 ...

  7. db2怎么恢复误删除的数据_db2数据库被误删后 oracle数据库误删数据恢复

    db2用户删除后db2数据库无法再启动怎么回事? 创建实例时,DB2的命令和环境变量会在/home/db2inst1中生成一个sqllib文件夹,即整个实例 当实例用户生成 db2icrt-u db2 ...

  8. oracle如何根据ID恢复部分数据,三种方法找回Oracle数据库误删除的数据

    三种方法找回Oracle数据库误删除的数据 最新动态来源:点击数:6141更新时间:2018/5/10 有很多朋友都遇到过在操作数据库时误删除某些重要数据的情况,如果数据库没有备份而且数据有十分重要的 ...

  9. 阿里云 | 如何恢复在ECS实例中误删除的数据

    概述 本文主要介绍在ECS实例中如何恢复误删除的数据. 详细信息 阿里云提醒您: 如果您对实例或数据有修改.变更等风险操作,务必注意实例的容灾.容错能力,确保数据安全. 如果您对实例(包括但不限于EC ...

  10. SQL Server如何还原误删除的数据-操作篇

    点击上方SQL数据库开发,关注获取SQL视频教程 SQL专栏 SQL数据库基础知识汇总 SQL数据库高级知识汇总 之前我们写了一篇用工具Log explorer还原误删除的教程,但是由于工具的版本限制 ...

最新文章

  1. Java架构-面试前必须知道的MySQL命令【explain】
  2. python介绍和用途-python数据类型介绍与使用
  3. 【倒计时】Qtum量子链全节点超级大奖1000QTUM,不要错过!
  4. 两经纬度之间的距离计算
  5. DCMTK:可加载的DICOM数据字典中的字典条目
  6. restfull知识点
  7. arachni web mysql数据库_Web安全扫描工具Arachni
  8. HTML 禁止数字因被自动识别为手机号,而被添加拨号链接样式
  9. 有两个程序员得了肺癌 都是30多岁的男人
  10. iOS-UICollectionView快速构造/拖拽重排/轮播实现
  11. GetTickCount64的使用
  12. Java项目-食堂菜品点评系统(SpringBoot + SpringSecurity + Thymeleaf + Redis)
  13. Android studio打开机智云APP(自动生成)
  14. iOS开发中常用的方法
  15. 下月苹果“小春晚”,M2 芯片终于要来了?
  16. java 实现写出倒立三角形的几种方法
  17. 悲观者往往正确,乐观者往往成功
  18. 服务器重启后启动php项目
  19. 分享一个Maven依赖查询网址
  20. 九度1001 A+B for Matrices

热门文章

  1. 《Unity3d-控制枪口的朝向代码》
  2. 屏蔽爬虫之robots.txt
  3. ruby DBI安装使用指南
  4. XVII Open Cup named after E.V. Pankratiev. GP of Siberia, Division 1
  5. 是用int还是用Integer?
  6. 用 Graphviz+pvtrace 可视化函数调用
  7. ORA-12170: TNS: 连接超时 问题
  8. 仿Linux中的cp操作
  9. 【老孙随笔】怎样才能当上项目经理?
  10. (原创)无废话C#设计模式之二十:Mediator