gpt4 book ai didi

c# - 以编程方式备份​​ Azure Sql 数据库

转载 作者:行者123 更新时间:2023-12-03 04:28:41 25 4
gpt4 key购买 nike

我创建了一个脚本来备份和恢复我的 SQL 数据库。我最近刚刚迁移到 Azure Sql Server。我的以下备份策略不再有效。对于我的程序,它通常会保存备份并创建一个后缀名为训练的新备份。看来Azure Sql Server的备份策略是完全不同的。请问如何以编程方式备份​​ Azure Sql 数据库并恢复它。

if (!sqlServer.Databases.Contains(databaseTraining))
{
var backupFile = string.Concat(sqlServer.Settings.BackupDirectory, "\\", database, "Training.BAK");

var sourceBackup = new Backup
{
Database = database,
Action = BackupActionType.Database
};

var destDevice = new BackupDeviceItem(backupFile, DeviceType.File);
sourceBackup.Devices.Add(destDevice);
sourceBackup.Initialize = true;

sourceBackup.SqlBackup(sqlServer);

var db = new Microsoft.SqlServer.Management.Smo.Database(sqlServer, databaseTraining);
db.Create();

var destinationRestore = new Restore
{
Database = databaseTraining,
Action = RestoreActionType.Database
};
destinationRestore.Devices.Add(destDevice);

var dataFile = new RelocateFile
{
LogicalFileName = destinationRestore.ReadFileList(sqlServer).Rows[0][0].ToString(),
PhysicalFileName = sqlServer.Databases[databaseTraining].FileGroups[0].Files[0].FileName
};

var logFile = new RelocateFile
{
LogicalFileName = destinationRestore.ReadFileList(sqlServer).Rows[1][0].ToString(),
PhysicalFileName = sqlServer.Databases[databaseTraining].LogFiles[0].FileName
};

destinationRestore.RelocateFiles.Add(dataFile);
destinationRestore.RelocateFiles.Add(logFile);

destinationRestore.ReplaceDatabase = true;
destinationRestore.NoRecovery = false;

destinationRestore.SqlRestore(sqlServer);

最佳答案

I recently just moved to Azure Sql Server. My backup strategy below no longer works

您观察到的是正确的,您的备份策略在 Azure 中不起作用..

如果只需要备份来确保像 OnPremises 那样的时间点恢复,则不需要,因为使用 azure,您可以根据您的级别获得时间点恢复功能。

enter image description here

如果您希望在本地服务器上恢复数据库以进行测试/其他目的..您可以使用以下链接..

1.) How do I copy SQL Azure database to my local development server?

2.) https://blogs.msdn.microsoft.com/mast/2013/03/03/different-ways-to-backup-your-windows-azure-sql-database/

关于c# - 以编程方式备份​​ Azure Sql 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39793367/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com