转:Log Explorer使用说明恢复被误删除的数据
一、介绍
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可以确定被删掉的原始数据行,并在完成时显示原始行数和实际恢复的行数,由此可以断定是否全部恢复
转自:https://blog.csdn.net/hch271510994/article/details/54091321
转:Log Explorer使用说明恢复被误删除的数据的更多相关文章
- Log Explorer使用说明
一.介绍 Log Explorer主要用于对MSSQLServer的事物分析和数据恢复.你可以浏览日志.导出数据.恢复被修改或者删除的数据(包括执行过update,delete,drop和trunca ...
- Log Explorer 使用说明(原创)
关于Log Explorer (我抄的) 介绍Log Explorer主要用于对MSSQLServer的事物分析和数据恢复.你可以浏览日志.导出数据.恢复被修改或者删除的数据(包括执行过update, ...
- 如何恢复sqlserver误删除的数据(摘)
一.借助第三方工具 1.sqlserver2005: Log Explorer http://www.cnblogs.com/whitney/archive/2008/08/22/1273879.ht ...
- orcal恢复delete误删除的数据
orcal的删除有3种:delete.truncate.drop. delete可以手动提交和回滚,且可以使用where:而truncate.drop执行即对表数据进行了修改,且不能使用where. ...
- Linux环境下利用句柄恢复Oracle误删除的数据文件
在误删除Oracle的数据文件后,如果未关闭数据库,文件句柄还没有释放,且被删除的数据文件占用的磁盘块未被复写,则可以利用句柄的方式来恢复数据文件.下面模拟恢复过程. (一)环境 OS版本:redha ...
- Log Explorer 恢复误删除、更新数据
一.介绍 详细参考:https://blog.csdn.net/jinjazz/article/details/2459692 转自:https://blog.csdn.net/hch27151099 ...
- Linux中利用extundelete恢复误删除的数据
利用extundelete工具恢复磁盘误删除的数据 原理: 简单介绍下关于inode的知识.在Linux下可以通过"ls -id"命令来查看某个文件或者目录的inode值,例如查看 ...
- 使用Log Explorer查看和恢复数据
由于一次意外操作,把QC数据库中的BUG表数据给删掉了.崩溃-上网找了下恢复方法,找到一款Log Explorer.下载安装使用后,发现这款软件的确不错,收藏ing. 本次的使用的Log Expl ...
- sql server 2005 使用Log Explorer查看和恢复数据
使用Log Explorer查看和恢复数据 Log Explorer 4.1.可用于SQL Server2005的日志查看工具 下载地址: http://download.csdn.net/ ...
随机推荐
- Java基础系列--throw、throws关键字
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/8484697.html 一.概述 throw和throws就是异常相关的关键字,在java中 ...
- TCP/IP协议学习(一)
一.网络模型 OSI七层模型:自上至下依次是 应用层,表示层,会话层,传输层,网络层,数据链路层,物理层 应用层:具体的应用协议如HTTP.SMTP.FTP.TELNET.DNS等 表示层:针对数据格 ...
- java实现带空格字符串的倒序输出
import org.junit.Test; public class StringtoChar { @Test public void main(){ String str ="hello ...
- 利用aiohttp制作异步爬虫
asyncio可以实现单线程并发IO操作,是Python中常用的异步处理模块.关于asyncio模块的介绍,笔者会在后续的文章中加以介绍,本文将会讲述一个基于asyncio实现的HTTP框架--a ...
- mysql分页存储过程一步一步实现
1. CREATE DEFINER=`root`@`localhost` PROCEDURE `P_HoverTreePages`( ), ) , ), ), ), IN `SortType` INT ...
- nginx常用命令参数
命令行参数: 常用命令: -c filename:设置配置文件. -t :不运行,而仅仅测试配置文件.nginx 将检查配置文件的语法的正确性,并尝试打开配置文件中所引用到的文件. -s :传递一个信 ...
- Failed at the @ watch script 'cross-env NODE_ENV=development 使用cross-env解决跨平台设置NODE_ENV的问题
今天在安装js依赖包时,根目录的package.json: { "private": true, "scripts": { "dev": & ...
- HTML标签笔记
换行符:<br/> 首部: <!DOCTYPE>: 说明html文档使用的标准, 在HTML5中仅为 <!DOCTYPE html>1.头标签 <head&g ...
- vue过滤器用法实例分析
过滤器: vue提供过滤器: capitalize uppercase currency.... ? 1 2 3 <div id="box"> {{msg|cu ...
- K8S RBAC
API Server 内部通过用户认证后,然后进入授权流程.对合法用户进行授权并且随后在用户访问时进行鉴权,是权限管理的重要环节. 在 kubernetes 集群中,各种操作权限是赋予角色(Role ...