日期:2011-05-02 15:20:00 来源:本站整理
SQL Server日记文件丧失的恢复办法[MSSQL防范]
本文“SQL Server日记文件丧失的恢复办法[MSSQL防范]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
1、 概述
在利用系统中,数据库常常是最核心的部份,一旦数据库破坏或破坏,将会带来宏大的丧失,所以数据库的管理越来越重要.我们在做数据库管理与保护工作中,不可避免会呈现各种各样的错误,本文针对数据库的日记文件丧失时若何操纵MDF文件恢复数据库的办法举行了研究.
2、 数据库的恢复
当数据库的主数据MDF文件无缺无损时,在丧失了LDF文件的情形下,若何操纵MDF文件恢复数据库?我们把sql server的日记文件分为两类:一类是无活动事件的日记,另一类是含活动事件的日记,按照差别的日记,采纳差别的办法来恢复数据库.
1. 无活动事件的日记恢复
无活动事件的日记丧失时,我们很简单操纵MDF文件直接恢复数据库,具体办法以下:
①.别离被质疑的数据库,可用企业管理器中的"别离数据库工具",大概用存储历程sp_detach_db别离数据库;
②操纵MDF文件附加数据库生成新的日记文件,可用企业管理器中的"附加数据库"的工具,大概用存储历程sp_attach_single_file_db附加数据库.
假如数据库的日记文件中含有活动事件,操纵此办法就不能恢复数据库.
2. 含活动事件的日记恢复
含有活动事件的日记丧失时,操纵上述办法就会呈现"数据库和日记文件不符合,不能附加数据库".关于这种情形下,我们采取以下办法:
①新建同名数据库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’ |
假如没有报告什么错误,便可以举行以下操作.
②设置数据库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就完好恢复.
3、 小结
日记文件丧失是一件非常危险的事情,很有大概你的数据库完好破坏.SQL Server数据库的恢复都是靠日记文件来完成,所以无论若何都要保证日记文件的存在,它至关重要.为了使我们的数据库万无一失,最好采取多种备份方法相结合,所以我们要从心里器重数据库的管理与保护工作.
以上是“SQL Server日记文件丧失的恢复办法[MSSQL防范]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |
评论内容只代表网友观点,与本站立场无关!
评论摘要(共 0 条,得分 0 分,平均 0 分)
查看完整评论