想使用C#将数据库备份从链接服务器A还原到链接服务器B上的数据库。喜欢使用SMO。
我可以从本地备份还原到本地计算机。
{
conn = new ServerConnection
{
ConnectionString = @"Data Source =
(localdb)\MSSQLLocalDb;Initial Catalog=master;Integrated Security=true",
};
try
{
//Restore Full
srv = new Server(conn);
//lsrv = srv.LinkedServers[@"DEVSQL\ALPHA"]; need to figure out how to restore to linked server instead of local.
//srv.KillAllProcesses("G4TestNew");
var res = new Restore();
res.Database = "G4TestNew";
res.Action = RestoreActionType.Database;
filePath = @"\\CABCSERVER\Database\Temp\Full.bak";
res.Devices.AddDevice(filePath, DeviceType.File);
res.ReplaceDatabase = true;
res.NoRecovery = true;
var dataFile = new RelocateFile("G4Test", @"C:\TBD\G4Test.mdf");
var logFile = new RelocateFile("G4Test_log", @"C:\TBD\G4TestNew.ldf");
res.RelocateFiles.Add(dataFile);
res.RelocateFiles.Add(logFile);
res.SqlRestore(srv);
}
编辑(添加更多详细信息):。 在这种情况下,可以通过“ sql服务器身份验证”访问链接的服务器,并且应用程序无法访问直接连接所需的凭据,并且只能使用“集成安全性”来连接到localdb。
答案 0 :(得分:2)
在SMO中,您不会连接到一台服务器,然后再管理链接的服务器。而是直接连接到目标服务器。例如:
ConnectionString = @"Data Source =
DEVSQL\ALPHA;Initial Catalog=master;Integrated Security=true",
srv = new Server(conn);