在用Asp.net對備份的資料庫檔案進行還原的時候,有時候會出現下面的錯誤異常:
[因為資料庫正在使用,所以未能獲得對資料庫的排它訪問權。 RESTORE DATABASE 操作異常終止。已將資料庫上下文改為 'master'。]
這個時候,自由等待其他進程釋放對應許可權後,才可還原成功!有沒有解決辦法呢?我參照【Java】對這個問題的解決方案,做了更新,問題解決。
[SQL代碼]--還原資料庫時資料庫正在使用導致資料庫無會還原,此儲存過存在msater資料庫下建立。exec killspid 'dbname' 結束此資料庫的進程,這樣才能還原資料庫
create proc killspid (@dbname varchar(20))
as
begin
declare @sql nvarchar(500)
declare @spid int
set @sql='declare getspid cursor for select spid from sysprocesses where dbid=db_id('''+@dbname+''')'
exec (@sql)
open getspid
fetch next from getspid into @spid
while @@fetch_status <> -1
begin
exec('kill '+@spid)
fetch next from getspid into @spid
end
close getspid
deallocate getspid
end
[C#代碼] /// <summary>
/// 恢複資料庫,可選擇是否可以強制還原(即在其他人在用的時候,依然可以還原)
/// </summary>
/// <param name="databasename">待還原的資料庫名稱</param>
/// <param name="databasefile">帶還原的備份檔案的完全路徑</param>
/// <param name="errormessage">恢複資料庫失敗的資訊</param>
/// <param name="forceRestore">是否強制還原(恢複),如果為TRUE,則exec killspid '資料庫名' 結束此資料庫的進程,這樣才能還原資料庫</param>
/// <returns></returns>
public bool RestoreDataBase(string databasename, string databasefile, ref string errormessage,bool forceRestore)
{
bool success = true;
string path = databasefile;
string dbname = databasename;
string restoreSql = "use master;";
if (forceRestore)//如果強制回複
restoreSql += string.Format("use master exec killspid '{0}';",databasename);
restoreSql += "restore database @dbname from disk = @path;";
SqlCommand myCommand = new SqlCommand(restoreSql, conn);
myCommand.Parameters.Add("@dbname", SqlDbType.Char);
myCommand.Parameters["@dbname"].Value = dbname;
myCommand.Parameters.Add("@path", SqlDbType.Char);
myCommand.Parameters["@path"].Value = path;
try
{
myCommand.Connection.Open();
myCommand.ExecuteNonQuery();
}
catch (Exception ex)
{
errormessage = ex.Message;
success = false;
}
finally
{
myCommand.Connection.Close();
}
return success;
}