[英]I want to restore a SQL Server database using C# code
我想 select 恢复路径然后 select 我的数据库备份文件并通过单击 Visual Studio 2019 中的按钮来恢复它。
我在下面有一些我已经写过的代码,但是我得到了一个错误。
string connection = ConfigurationManager.ConnectionStrings["dbx"].ConnectionString;
SqlConnection con = new SqlConnection(connection);
con.Open();
String sqlquery = "Use Master ALTER DATABASE databasename SET OFFLINE WITH ROLLBACK IMMEDIATE RESTORE DATABASE FHMTailorDB FROM DISK ='" + RestoreTextBox.Text + "' ALTER DATABASE databasename SET ONLINE WITH ROLLBACK IMMEDIATE";
SqlCommand cmd = new SqlCommand(sqlquery, con);
cmd.ExecuteNonQuery();
con.Close();
con.Dispose();
lblError.Text = "Database Restore successfully";
错误:
System.Data.SqlClient.SqlException:'用户无权更改数据库'databasename',数据库不存在,或数据库不在允许访问检查的 state 中。
ALTER DATABASE 语句失败。
文件“F:\FHMTailorManager\FHMTailorDB.mdf”的目录查找失败,出现操作系统错误 2(系统找不到指定的文件。)。
文件“FHMTailorDB”无法恢复到“F:\FHMTailorManager\FHMTailorDB.mdf”。 使用 WITH MOVE 标识文件的有效位置。
文件“F:\FHMTailorManager\FHMTailorDB_log.ldf”的目录查找失败,出现操作系统错误 2(系统找不到指定的文件。)。
文件“FHMTailorDB_log”无法恢复到“F:\FHMTailorManager\FHMTailorDB_log.ldf”。 使用 WITH MOVE 标识文件的有效位置。 在规划 RESTORE 语句时发现了问题。 以前的消息提供了详细信息。
RESTORE DATABASE 异常终止。
用户无权更改数据库“数据库名称”,数据库不存在,或数据库不在允许访问检查的 state 中。
ALTER DATABASE 语句失败。
将数据库上下文更改为“主”。
你有两个问题
您的连接字符串提供的第一个凭据没有足够的权限来完成使数据库脱机的任务。
第二个是您尝试从客户端 PC-a 访问 select MDF/LDF 文件,而服务器端的文件系统不知道或无权访问该文件夹。
所以,我的回答是你需要尝试一些完全不同的东西。
尝试使用 SMO。 网上有一篇文章轻轻地向读者介绍了SMO。
文章指出了 GitHub 上的解决方案,其中包含您需要的一切。
这意味着一组用 .NET ( C# ) 编写的用于备份、恢复等的自动化程序。
所以,试试这个Programming SQL Server with SQL Server Management Objects Framework
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.