速达3000数据库里只有MDF文件,LDF文件找不到了,致使数据库无法导入,如何才能用MDF文件导出LDF文件

速达3000数据库里只有MDF文件,LDF文件找不到了,致使数据库无法导入,如何才能用MDF文件导出LDF文件,第1张

A.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。

B.停掉数据库服务器

C.将刚才生成的数据库的日志文件test_logldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_datamdf。

D.启动数据库服务器。此时会看到数据库test的状态为“置疑”。这时候不能对此数据库进行任何 *** 作。

E.设置数据库允许直接 *** 作系统表。此 *** 作可以在SQL Server Enterprise Manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。

use master

go

sp_configure 'allow updates',1

go

reconfigure with override

go

F.设置test为紧急修复模式

update sysdatabases set status=-32768 where dbid=DB_ID('test')

此时可以在SQL Server Enterprise Manager里面看到该数据库处于“只读\置疑\脱机\紧急模式”可以看到数据库里面的表,但是仅仅有系统表

G.下面执行真正的恢复 *** 作,重建数据库日志文件

dbcc rebuild_log('test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_logldf')

执行过程中,如果遇到下列提示信息:

服务器: 消息 5030,级别 16,状态 1,行 1

未能排它地锁定数据库以执行该 *** 作。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了test库的系统表,那么退出SQL Server Enterprise Manager就可以了。

正确执行完成的提示应该类似于:

警告: 数据库 'test' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

此时打开在SQL Server Enterprise Manager里面会看到数据库的状态为“只供DBO使用”。此时可以访问数据库里面的用户表了。

H.验证数据库一致性(可省略)

dbcc checkdb('test')

一般执行结果如下:

CHECKDB 发现了 0 个分配错误和 0 个一致性错误(在数据库 'test' 中)。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

I.设置数据库为正常状态

sp_dboption 'test','dbo use only','false'

如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。

J.最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。因为平时直接 *** 作系统表是一件比较危险的事情。当然,我们可以在SQL Server Enterprise Manager里面恢复,也可以使用如下语句完成

sp_configure 'allow updates',0

go

reconfigure with override

go

参考下列说明:

/--说明:

下面的代码演示了如何利用日志还原功能,将主数据库中的数据变化及时反馈到备用数据库中

备用数据库的数据可以随时用于查询,但不能被更新(备用数据库只读)。

--/

--首先,创建一个演示用的数据库(主数据库)

CREATE DATABASE Db_test

ON

( NAME = Db_test_DATA,

      FILENAME = 'c:\Db_testmdf' )

LOG ON

( NAME = Db_test_LOG,

   FILENAME = 'c:\Db_testldf')

GO

--对数据库进行备份

BACKUP DATABASE Db_test TO DISK='c:\test_databak' WITH FORMAT

GO

--把数据库还原成备用数据库(演示主数据库与这个备用数据库之间的同步)

RESTORE DATABASE Db_test_bak FROM DISK='c:\test_databak'

WITH REPLACE,STANDBY='c:\db_test_bakldf'

,MOVE 'Db_test_DATA' TO 'c:\Db_test_datamdf'

,MOVE 'Db_test_LOG' TO 'c:\Db_test_logldf'

GO

--启动 SQL Agent 服务

EXEC masterxp_cmdshell 'net start sqlserveragent',no_output

GO

--创建主服务器数据训与备用服务器数据库之间同步的作业

DECLARE  @jogid uniqueidentifier

EXEC msdbsp_add_job

@job_id = @jogid OUTPUT,

@job_name = N'数据同步处理'

--创建同步处理步骤

EXEC msdbsp_add_jobstep

@job_id = @jogid,

@step_name = N'数据同步',

@subsystem = 'TSQL',

@command = N'

--主数据库中进行日志备份

BACKUP LOG Db_test TO DISK=''c:\test_logbak'' WITH FORMAT

--备用数据库中还原主数据库的日志备份(应用主数据库中的最新变化

--实际应该时主数据库备份与备用数据库的还原作业应该分别在主服务器和备用服务器上建立,并且备份文件应该放在主服务器和备用都能访问的共享目录中

RESTORE LOG Db_test_bak FROM DISK=''c:\test_logbak'' WITH STANDBY=''c:\test_logldf''',

@retry_attempts = 5,

@retry_interval = 5

--创建调度(每分钟执行一次)

EXEC msdbsp_add_jobschedule

@job_id = @jogid,

@name = N'时间安排',

@freq_type=4,

@freq_interval=1,

@freq_subday_type=0x4,

@freq_subday_interval=1,

@freq_recurrence_factor=1

-- 添加目标服务器

EXEC msdbdbosp_add_jobserver

@job_id = @jogid,

@server_name = N'(local)'

GO

--通过上述处理,主数据库与备用数据库之间的同步关系已经设置完成

--下面开始测试是否能实现同步

--在主数据库中创建一个测试用的表

CREATE TABLE Db_testdboTB_test(ID int)

GO

--等待1分钟30秒(由于同步的时间间隔设置为1分钟,所以要延时才能看到效果)

WAITFOR DELAY '00:01:30'

GO

--查询一下备用数据库,看看同步是否成功

SELECT FROM Db_test_bakdboTB_test

/--结果:

ID         

-----------

(所影响的行数为 0 行)

--/

--测试成功

GO

--最后删除所有的测试

DROP DATABASE Db_test,Db_test_bak

EXEC msdbsp_delete_job @job_name=N'数据同步处理'

GO

/===========================================================/

/--服务器档机处理说明

使用这种方式建立的数据库同步,当主数据库不可用时(例如,主数据库损坏或者停机检修)

可以使用以下两种方法使备用数据库可用。

--/

--1 如果主数据库损坏,无法备份出最新的日志,可以直接使用下面的语句使备用数据库可读写(丢失最近一次日志还原后的所有数据)。

--RESTORE LOG Db_test_bak WITH RECOVERY

--2 如果主数据库可以备份出最新日志,则可以使用下面的语句。

--先备份主数据库的最新的事务日志

--BACKUP LOG Db_test TO DISK=''c:\test_logbak'' WITH FORMAT

--再在备用数据库中恢复最新的事务日志,并且使备用数据库可读写(升级为主数据库)

--RESTORE LOG Db_test_bak FROM DISK='c:\test_logbak'

简单地说:

你的sql服务要使用指定的windows用户登陆, 而不能使用"本地系统帐户"

用于登陆sql服务的用户要求对共享目录具有所有权限

 如果你的电脑没有加入到域, 还必须保证源和目标服务器的sql服务设置的登陆用户是一样的(用户名和密码都一样)

网络备份主要是权限设置问题, 参考下面的备份文件共享目录权限设置方法去解决目录的共享权限就可以了

下面假设是假设A服务器上的数据库备份到B服务器上的共享目录权限设置(两台服务器应该在局域网内,允许目录共享访问)::

机器A,B创建一个同名的windows用户,用户组设置为administrators,并设置相同的密码,做为备份文件夹文件夹的有效访问用户, *** 作:

我的电脑

--控制面板

--管理工具

--计算机管理

--用户和组

--右键用户

--新建用户

--建立一个隶属于administrator组的登陆windows的用户

在B机器器上,新建一个共享目录,做为备份文件的存放目录, *** 作:

我的电脑--D:\ 新建一个目录,名为: BAK

--右键这个新建的目录

--属性--共享

--选择"共享该文件夹"

--通过"权限"按纽来设置具体的用户权限,保证第一步中创建的用户具有对该文件夹的所有权限

--确定

设置 MSSQLSERVER 及 SQLSERVERAGENT 服务的启动用户

开始--程序--管理工具--服务

--右键 MSSQLSERVER

--属性--登陆--选择"此账户"

--输入或者选择第一步中创建的windows登录用户名

--"密码"中输入该用户的密码

--确定

--同样的方法设置 SQLSERVERAGENT

在A机器上完成对B机器BAK目录的映射

查询分析器中执行下面的语句,检验是否成功:

  exec masterxp_cmdshell 'dir 映射的盘符'

A服务器上做备份计划

备注:创建一个新的用户只是为了让MSSQLSERVER服务的启动帐户与共享目录的有效访问同名且密码相同,这样才能通过验证(所以你也可以用其他有效的用户来代替,只需要满足用户名和密码相同,并且拥有足够的权限)

*** 作方式一:

·将这两个文件复制到\\用友T1-商贸宝批发零售版\\服务器\\data下。(这些文件存放在\"原软件安装路径\\用友T1-商贸宝批发零售版\\服务器\\data\"下)

·进入windows *** 作系统的开始->程序->Microsoft

SQL

Server->查询分析器中,在d出\"连接到SQL

Server\"窗口中输入密码(此项安装SQL数据库时输入的密码,如当时未输入密码,在此也无需输入),点击\"确认\"后,在出现的可输入的空白窗口处,录入如下内容:

exec

sp_attach_db\'新建的数据库名称\',\'mdf文件在本机的存放路径\',\'ldf文件在本机的存放路径\'

例如:exec

sp_attach_db\'dbname\',\'c:\\用友T1-商贸宝批发零售版\\服务器\\data\\mdf\',\'c:\\用友T1-商贸宝批发零售版\\服务器\\data\\ldf\'

请严格按照此格式进行书写,输入完成后点击窗口工具栏中的绿色三角形按钮或点击键盘按键\"F5\"运行,如现成功提示后,完成此项 *** 作。

·进入windows *** 作系统的开始->程序->Microsoft

SQL

Server->企业管理器,点击控制台根目录下的\"+\"号,直到看到一个名为\"数据库\"文件夹,再次点击\"数据库\"左边的\"+\"号,找到\"master\"数据库,点击master旁边的\"+\"号,找到其下级目录\"表\",点击\"表\"后,在右边的窗口中出现很多数据表文件,找到名为\"sub_list\"的文件,右键单击此项,在d出的菜单中选中\"打开表->返回所有行\",此时出现一个表格,在dbname中输入你的数据库名,在ZTname中输入你的账套名,flgver对应列输入版本信息,然后点击上面工具栏中的感叹号\"!\",退出完成数据恢复 *** 作。

*** 作方式二:

·将这两个文件从\"软件安装路径\\用友T1-商贸宝批发零售版\\服务器\\data\"剪切拷贝到其它目录下。

·进入软件中,创建一个新账套,数据库名称为mdf的文件名相同。例如文件为fzbmdf,则创建的新账套的账套名称可以任意取,但数据库名称必须是fzb,此时在\"软件安装路径\\用友T1-商贸宝批发零售版\\服务器\\data\"会生成两个新文件fzbmdf和fzbldf。

·将原来拷贝到其它路径下的mdf文件和ldf文件拷回到\"软件安装路径\\用友T1-商贸宝批发零售版\\服务器\\data\"覆盖新建账套生成的同名文件,完成数据恢复 *** 作。

注意:客户安装数据库文件为MSDE2000可采用方式二进行处理,但不能采用方式一进行数据恢复。

1、确定SQL数据库安装路径与所用SQL数据库名称

2、点击开始--程序--Microsoft

SQL

Server--查询分析器--确定进入软件里点击菜单帮助--Transact-sql帮助(S)--索引--输入(sp_attach_single_file_db),右边对框里找下命令或者空白处直接输入下命令:

EXEC

sp_detach_db

@dbname

=

'pubs'returnEXEC

sp_attach_single_file_db

@dbname

=

'pubs',

@physname

=

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\pubsmdf'

注意:return加入命令语名数据库(LDF与MDF)分离再数据库名改回所要选即pubs改J2002即:

EXEC

sp_detach_db

@dbname

=

'

J2002'returnEXEC

sp_attach_single_file_db

@dbname

=

'

J2002',

@physname

=

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\

J2002mdf'

3、输入命令点击菜单查询--执行下面对框出现命令"命令已成功完成"

4、删除命令(EXEC

sp_detach_db

@dbname

=

'

J2002'

return)进入安装SQL数据库路径里J2002ldf文件重命名

5、接着第3点开始点击菜单查询--执行下面对框出现命令"设备激活错误物理文件名

'C:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\J200188ldf'

能有误已创建名

'c:\Program

Files\Microsoft

SQL

Server\MSSQL\Data\j200188_logLDF'

新日志文件"

以上就是关于速达3000数据库里只有MDF文件,LDF文件找不到了,致使数据库无法导入,如何才能用MDF文件导出LDF文件全部的内容,包括:速达3000数据库里只有MDF文件,LDF文件找不到了,致使数据库无法导入,如何才能用MDF文件导出LDF文件、SQL SERVER 只有ldf日志文件怎么恢复数据、用友T1商贸宝只有*.mdf和*.ldf文件时,如何恢复数据 等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/zz/10079862.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-05
下一篇 2023-05-05

发表评论

登录后才能评论

评论列表(0条)

保存