我的问题真的很简单。
我有一个包含一个或多个备份集的 .bak 文件。
当我使用 SMO 通过此 .bak 文件恢复数据库时,只需要第一个备份集即可完成其工作。它似乎忽略了剩余的集合。
为什么 ?
看我的代码:
//Sets the restore configuration
Restore restore = new Restore()
{
Action = RestoreActionType.Database,
Database = _databaseToRestore.DatabaseName,
ReplaceDatabase = true
};
restore.Devices.Add(new BackupDeviceItem(_backupFilePath, DeviceType.File));
Server server = new Server(_databaseToRestore.ServerName);
DataTable fileList = restore.ReadFileList(server);
string serverDataFolder = server.Settings.DefaultFile;
if (string.IsNullOrEmpty(serverDataFolder))
serverDataFolder = server.Information.MasterDBPath;
foreach (DataRow file in fileList.Rows)
{
restore.RelocateFiles.Add(
new RelocateFile((string)file["LogicalName"],
Path.Combine(serverDataFolder, _databaseToRestore.DatabaseName + Path.GetExtension((string)file["PhysicalName"]))));
}
//Gets the exclusive access to database
server.KillAllProcesses(_databaseToRestore.DatabaseName);
restore.Wait();
restore.SqlRestore(server);
我认为 BackupDeviceItem 可以向我提供有关内部有多少备份集的反馈,这样我可以警告用户,但事实并非如此。
有人对此有线索吗?
谢谢你的时间。
好的,解决了我的问题。
重要的字段是FileNumber
on the Restore
目的。
默认值是 1,这就是为什么它总是使用我的第一个备份集。
我只需将此属性设置为文件中备份集的数量,现在它需要完成最新的备份。
注意:此问题不涉及差异备份。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)