当前位置:首页 > 系统运维 > 正文内容

SQLServer日志文件丢失,恢复并不难!

a8116255316年前 (2010-07-20)系统运维5

此文章主要讲述的是SQLServer日志文件在丢失的情况下的恢复方案,相信假如你掌握了SQLServer日志文件在丢失的情况下的恢复方这实际操作技巧,会在以后的学习或是工作中带来很大的帮助。

一、 概述

在应用系统中,数据库往往是最核心的部分,一旦数据库毁坏或损坏,将会带来巨大的损失,所以数据库的管理越来越重要。我们在做数据库管理与维护工作中,不可避免会出现各种各样的错误,本文针对数据库的SQLServer日志文件丢失时如何利用MDF文件恢复数据库的 *** 进行了研究。

二、 数据库的恢复

当数据库的主数据MDF文件完好无损时,在丢失了LDF文件的情况下,如何利用MDF文件恢复数据库?我们把SQL Server日志文件分为两类:一类是无活动事务的日志,另一类是含活动事务的日志,根据不同的日志,采取不同的 *** 来恢复数据库。

1. 无活动事务的日志恢复

无活动事务的日志丢失时,我们很容易利用MDF文件直接恢复数据库,具体 *** 如下:

①.分离被质疑的数据库,可用企业管理器中的"分离数据库工具",或者用存储过程sp_detach_db分离数据库;

②利用MDF文件附加数据库生成新的日志文件,可用企业管理器中的"附加数据库"的工具,或者用存储过程sp_attach_single_file_db附加数据库。

假如数据库的SQLServer日志文件中含有活动事务,利用此 *** 就不能恢复数据库。

2. 含活动事务的日志恢复

含有活动事务的日志丢失时,利用上述 *** 就会出现"数据库和SQLServer日志文件不符合,不能附加数据库"。对于这种情况下,我们采用如下 *** :

①新建同名数据库AAA,并设它为紧急模式

停止SQL Server服务器;

把数据库主数据MDF文件移走;

启SQL Server服务器,新建一个同名的数据库AAA;

停止SQL Server服务器,把移走的MDF文件再覆盖回来;

启动SQL Server服务器,把AAA设为紧急模式,不过默认情况下,系统表是不能随便修改的,必须首先设置一下使其能被修改,运行以下语句即可:

Use Master  Go  sp_configure ’allow updates’,1  reconfigure with override  Go 

接着运行以下语句,把AAA数据库设为紧急模式,即把Sysdatabases表中AAA数据库的status属性设为’37268’,就表示把AAA数据库处于紧急模式。

update sysdatabases set status=32768 where hame=’AAA’ 

假如没有报告什么错误,就可以进行以下操作。

②设置SQLServer日志文件AAA为单用户模式,并检查数据库

重启SQL Server服务器;

把数据库AAA设为单用户模式

Sp_dboption ’AAA’, ’single user’, ’true’ 

运行以下语句,检查数据库AAA

DBCC CHECKDB(’AAA’) 

假如没有什么大的问题就可以把数据库的状态改回去。

③还原数据库的状态

运行以下语句,就可以把数据库的状态还原:

update sysdatabases set status=28 where name=’AAA’  sp_configure ’allow updates’,0  reconfigure with override  Go 

假如没有什么大的问题,刷新一下数据库,数据库AAA又会出现在你面前,但目前恢复工作还没有做完,此时的数据库仍不能工作,还要进行下面的处理,才能真正恢复。

④利用DTS的导入导出向导,把数据库AAA导入到一个新建数据库BBB中

新建一个数据库BBB;

右击BBB,选择IMPORT功能,打开导入向导;

目标源选择"在SQL Server数据库之间复制对象和数据库",这样可以把表结构,数据视图和存储过程导入到BBB中

再用此功能把BBB库替换成原来的AAA库即可。

到此为止,数据库AAA就完全恢复。

三、 小结

SQLServer日志文件丢失是一件非常危险的事情,很有可能你的数据库彻底毁坏。SQL Server数据库的恢复都是靠日志文件来完成,所以无论如何都要保证日志文件的存在,它至关重要。为了使我们的数据库万无一失,更好采用多种备份方式相结合,所以大家要从心里重视数据库的管理与维护工作。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://2345hao.cn/blog/index.php/post/22125.html

分享给朋友:

“SQLServer日志文件丢失,恢复并不难!” 的相关文章

windows 7/8.1正在启动windows时间长的解决方法

windows 7/8.1正在启动windows时间长的解决方法

正在启动windows时间长怎么办 小编带来了Windows 7/8.1正在启动windows时间长解决方法,假如有朋友在安装完Windows系统之后一直停留在“正在启动windows”的话,不妨试一试下文的方法哦~ 原因:Windows 7/8.1不完全支持UEFI,需要CSM(Comp...

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

解决windows 7无法将程序锁定到任务栏或附到开始菜单的方法

出现该问题的原因是由于使用第三方优化软件消除快捷方式的小箭头引起的。 1、在开始搜索框中键入“regedit”,按回车键打开注册表编辑器。 2、依次定位到以下分支:HKEY_CLASSES_ROOTlnkfile。 3、在lnkfile项上鼠标右键单击“新建”——“字符串值”。...

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

解决方法: 其实处理这些使用流氓软件,需要将相关的.exe文件删除,使它不能再运行,或者直接清除这个服务本身,使计算机重启的时候,它不会再启动。比如Hijackthis扫描,在扫描日志中,一般会把非Windows系统的服务以023的方式列出来,如下面这段: O23 - ...

Windows7播放电影视频蓝屏无论什么格式都会蓝屏

Windows7播放电影视频蓝屏无论什么格式都会蓝屏

问:我在Windows 7 Ultimate X64下播放电影视频时,不管什么格式都会蓝屏,错误代码“0x00000124”。换解码器、播放器不行,换驱动、内存也不管用。在不同的电脑上也试过,仍然蓝屏。请问是哪里的问题,如何解决 答:64位 Windows 7直接使用PotPlayer x64就...

windows 7/8/xp系统关闭自动播放功能禁止音频媒体自动播放

windows 7/8/xp系统关闭自动播放功能禁止音频媒体自动播放

Windows 7/8系统: 控制面板——自动播放——取消掉为所有媒体和设备设置自动播放 winXP系统: 开始—运行—gpedit.msc—计算机配置—管理模板—系统—关闭自动播放—已启用—所有驱动器—确定  关闭自动运行功能说明: 一旦您将媒体插入驱动器...

windows 7为什么老掉线 windows 7使用迅雷或快车下载的时候老掉

windows 7为什么老掉线 windows 7使用迅雷或快车下载的时候老掉

经过几天的测试后发现,Windows 7用户反映的情况确实存在,但并没有达到“频繁”的情况。同时,也并非是迅雷或快车抢了带宽。(即便是抢了带宽,表现的形式也是页面打开慢,而非是掉线),寻找问题的原因过程中,我们认为是Windows 7系统对于网卡的电源管理的默认设置造成的。 下面,就以Window...