Asp.net還原資料庫失敗的解決方案

來源:互聯網
上載者:User
在用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;
    }

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.