如何使用C#SMO将备份从一台链接服务器还原到另一台链接服务器

时间:2019-06-26 01:22:38

标签: c# sql-server .net-core linked-server smo

想使用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。

1 个答案:

答案 0 :(得分:2)

在SMO中,您不会连接到一台服务器,然后再管理链接的服务器。而是直接连接到目标服务器。例如:

ConnectionString = @"Data Source =
 DEVSQL\ALPHA;Initial Catalog=master;Integrated Security=true",
srv = new Server(conn);