查看: 262|回复: 0

[SQLServer] SQL语句还原数据库并移动文件到指定路径

发表于 2017-12-7 08:00:01

用SQL语句还原数据库时如果不指定数据库文件的存储路径,则默认把数据文件和日志文件存放到与原数据库相同的文件路径中,这样可能会产生错误,比如执行下面的语句:

  1. restore database SmartDev_11_28
  2. from disk='D:\Backup\SmartDev_20170904010000_413.bak'
复制代码

得到如下的错误信息:

想要在语句中指定文件路径需要用with move,

restore database 数据库名

from disk='备份文件路径'

with move '逻辑文件名' to '还原后数据库数据文件存放路径'

move '逻辑日志名' to '还原后数据库日志文件存放路径'

这里的逻辑文件名和逻辑日志名可以通过下面的语句来查看:

  1. restore filelistonly
  2. from disk='D:\Backup\SmartDev_20170904010000_413.bak'
复制代码

还原代码如下:

  1. restore database SmartDev_11_28
  2. from disk='D:\Backup\SmartDev_20170904010000_413.bak'
  3. with recovery,
  4.   move 'Intertek.Smart.Dev' to 'D:\DataBase\SZDBF8NBD2\SmartDev_11_28\SmartDev_11_28.mdf',
  5.   move 'FileStreamGroup_4D837C1B' to 'D:\DataBase\SZDBF8NBD2\SmartDev_11_28\SmartDev_FileStreamGroup_4D837C1B.mdf',
  6.   move 'Intertek.Smart.Dev_log' to 'D:\DataBase\SZDBF8NBD2\SmartDev_11_28\SmartDev_11_28.ldf',
  7.   move 'filestream_data' to 'D:\DataBase\SZDBF8NBD2\SmartDev_11_28\filestream_data',
  8.   move 'FileStream1' to 'D:\DataBase\SZDBF8NBD2\SmartDev_11_28\FileStream1'
复制代码

还原数据库成功。

还原后数据库各文件存放在该目录下。



回复

使用道具 举报

关闭

站长推荐上一条 /1 下一条