[英]Create SQL Server Backup in c#
我正在尝试从我的代码创建 sql 服务器备份并执行此操作。 但是当路径在驱动器 C 中时:(示例:文档或桌面)无法创建备份。 有什么问题?
try
{
string DES = GenerateBackupLocation(Destination);
string databaseName = "MyDataBase";
Backup sqlBackup = new Backup();
sqlBackup.Action = BackupActionType.Database;
sqlBackup.BackupSetDescription = "BackUp of:" + databaseName + "on" + DateTime.Now.ToShortDateString();
sqlBackup.BackupSetName = "FullBackUp";
sqlBackup.Database = databaseName;
BackupDeviceItem deviceItem = new BackupDeviceItem(DES + "\\" + databaseName + ".bak", DeviceType.File);
SqlConnection con = new SqlConnection(Connectionstring);
ServerConnection connection = new ServerConnection(con);
Server sqlServer = new Server(connection);
sqlServer.ConnectionContext.StatementTimeout = 60 * 60;
Database db = sqlServer.Databases[databaseName];
sqlBackup.Initialize = true;
sqlBackup.Checksum = true;
sqlBackup.ContinueAfterError = true;
sqlBackup.Devices.Add(deviceItem);
sqlBackup.Incremental = false;
sqlBackup.ExpirationDate = DateTime.Now.AddDays(3);
sqlBackup.LogTruncation = BackupTruncateLogType.Truncate;
sqlBackup.FormatMedia = false;
sqlBackup.SqlBackup(sqlServer);
sqlBackup.Devices.Remove(deviceItem);
Message = "Backup Ok";
}
catch
{
Message = "Can't Create Backup";
}
最可能的情况是您尝试备份到 SQL 服务器服务(即不是您)没有写入权限的文件夹。
运行 SQL 服务器配置管理器,检查 SQL 服务器执行的身份。 检查他们对该路径的许可。
此外,而不是所有的备份设备的东西,等等,你可能更容易执行 SQL 服务器命令来做备份,即 BACKUP dbname TO DISK = 'path' WITH options;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.