码迷,mamicode.com
首页 > 数据库 > 详细

RESTORE DATABASE命令还原SQLServer 数据库 bak

时间:2015-10-14 21:39:03      阅读:292      评论:0      收藏:0      [点我收藏+]

标签:

今天在sqlServer20005 的management studio里使用bak文件还原数据库的时候,总是失败!
技术分享
Restore failed for Server ‘ADANDELI‘.  (Microsoft.SqlServer.Smo)
An exception occurred while executing a Transact-SQL statement or batch. (Microsoft.SqlServer.ConnectionInfo
The backup set holds a backup of a database other than the existing ‘AAA‘ database.
RESTORE DATABASE is terminating abnormally. (Microsoft SQL Server,错误: 3154)

找不到原因(已经选择了"overwrite the existing database"),只能使用命令来还原了,不知道为什么会这样.技术分享

技术分享--返回由备份集内包含的数据库和日志文件列表组成的结果集。
技术分享--主要获得逻辑文件名
技术分享USE master
技术分享RESTORE FILELISTONLY
技术分享   FROM DISK = ‘g:\back.Bak‘ 
技术分享Go
技术分享************************************************
技术分享/*
技术分享利用bak恢复数据库,强制还原(REPLACE)
技术分享STATS = 10 每完成10%显示一条记录
技术分享DBTest和DBTest_log是上面g:\back.Bak里的逻辑文件
技术分享*/
技术分享USE master
技术分享RESTORE DATABASE DB 
技术分享   FROM DISK = ‘g:\back.Bak‘
技术分享   WITH MOVE ‘DBTest‘ TO ‘E:\Program Files\Microsoft SQL Server2005\Data\DB.mdf‘, 
技术分享   MOVE ‘DBTest_log‘ TO ‘E:\Program Files\Microsoft SQL Server2005\Data\DB_log.ldf‘,
技术分享STATS = 10, REPLACE
技术分享GO
技术分享++++++++++++++++++++++++++++++++
技术分享
技术分享/*
技术分享备份数据DB 到.bak文件。然后利用此bak文件恢复一个新的数据库DBTest。
技术分享*/
技术分享USE master
技术分享BACKUP DATABASE DB 
技术分享  TO DISK = ‘g:\DBBack0930.bak‘ 
技术分享RESTORE FILELISTONLY 
技术分享  FROM DISK = ‘g:\DBBack0930.bak‘ 
技术分享RESTORE DATABASE DBTest 
技术分享  FROM DISK = ‘g:\DBBack0930.bak‘ 
技术分享  WITH MOVE ‘DBTest‘ TO ‘E:\Program Files\Microsoft SQL Server2005\Data\DBTest.mdf‘, 
技术分享  MOVE ‘DBTest_log‘ TO ‘E:\Program Files\Microsoft SQL Server2005\Data\DBTest_log.ldf‘
技术分享GO 
技术分享---******************************
 
http://www.cnblogs.com/adandelion/archive/2006/09/30/519534.html

RESTORE DATABASE命令还原SQLServer 数据库 bak

标签:

原文地址:http://www.cnblogs.com/chen110xi/p/4878683.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!