天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

asp.net 因為數據庫正在使用的解決方法

這個問題困惑我好長的時間,在網上搜,也沒完全的解決方案,不是過于簡單,就是亂說,有的論壇上還沒人回答這個問題.今天我徹底解決這個問題,并在C#里測試完全通過.現在把他寫出來,希望對朋友們有幫助(如要轉載,記得給我版權哦.嘿嘿!!!).以下信息是綜合網上的資料和我的實際問題,整理出來的.
備份:
在備份按鈕里寫:
復制代碼 代碼如下:
protected void Button1_Click(object sender, EventArgs e)
{
string path = "e://MAZ數據庫備份//" + Menu+ ".bak";
if (File.Exists(path))
{
File.Delete(path);//注意,這個步驟很重要,如果重復,在備份的數據,就會變成,

//你剛開始的數據,所以每次都要先刪除.

      }
if (!File.Exists(path))
{
FileStream fs = File.Create(path);

fs.Close();
}
string backupstr="backup database Test to disk='"+path+"';";
SqlConnection con = new SqlConnection("server=localhost;database=Menu;uid=sa;pwd=sa;");
SqlCommand cmd = new SqlCommand(backupstr, con);
try
{
con.Open();
cmd.ExecuteNonQuery();
MessageBox.Show("備份成功!");
connection.Close();

}
catch (Exception ex)
{
string stringError = ex.ToString();
MessageBox.Show("備份失敗!");
connection.Close();
}
}

還原:
在還原按鈕里寫:
復制代碼 代碼如下:
protected void Button2_Click(object sender, EventArgs e)
{
string path = "e://MAZ數據庫備份//" + Menu+ ".bak";


string connectionStringTest = "server=localhost ;database=master;uid=sa;pwd=sa";

SqlConnection connection = new SqlConnection(connectionStringTest);
string backupstr = "restore database Menu from disk='" + path + "';";

try
{
string sql = "exec killspid '" + Menu+ "'";//這個很關鍵,要不然就出現題目上的錯誤了
SqlCommand cmd = new SqlCommand(sql, connection);
connection.Open();

cmd.ExecuteNonQuery();
cmd = new SqlCommand(backupstr, connection);
cmd.ExecuteNonQuery();
MessageBox.Show("恢復成功!");
connection.Close();
}
catch (Exception ex)
{
string stringError = ex.ToString();
MessageBox.Show("恢復失敗!");
connection.Close();
}


}

存儲過程 killspid
復制代碼 代碼如下:
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

AspNet技術asp.net 因為數據庫正在使用的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲三级大片 | 玩弄朋友娇妻呻吟交换电影 | 国产美女裸身网站免费观看视频 | jlzzzjizzzjlzzz亚洲 | 国产喷水1区2区3区咪咪爱AV | 在线中文高清资源免费观看 | 亚洲视频在线观看 | 亚洲 欧美 制服 校园 动漫 | 入禽太深在线观看免费高清 | 迈开腿让我看下你的小草莓声音 | 手机在线亚洲日韩国产 | 高傲教师麻麻被同学调教123 | 免费人成网站在线观看10分钟 | 大胸美女被c | 久草免费视频在线观看 | 99精品小视频 | 99久久精品互换人妻AV | 久久国产露脸老熟女熟69 | 2020国产成人免费视频 | 久久国产免费 | 欧美xxbb| 亚洲精品国产A久久久久久 亚洲精品国产AV成人毛片 | 在线观看国产视频 | 男污女XO猛烈的动态图 | 日本aaaa| 伊人不卡久久大香线蕉综合影院 | 男女交性视频无遮挡全过程 | 亚洲国产综合久久久无码色伦 | 暖暖视频在线高清播放 | 绑着男军人的扒开内裤 | 肉多荤文高h羞耻校园 | 亚洲高清视频网站 | 国产午夜人成在线视频麻豆 | 动漫美女人物被黄漫在线看 | 国产成人无码免费精品果冻传媒 | 各种场合肉H校园1V1 | 强行撕开衣服捏胸黄文 | 99久久99久久久精品齐齐鬼色 | 伦理电影v男人天堂 | 少妇无码太爽了视频在线播放 | 日韩一本道无码v |