国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

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

2024-07-10 12:53:17
字體:
來源:轉載
供稿:網友
這個問題困惑我好長的時間,在網上搜,也沒完全的解決方案,不是過于簡單,就是亂說,有的論壇上還沒人回答這個問題.今天我徹底解決這個問題,并在C#里測試完全通過.現在把他寫出來,希望對朋友們有幫助(如要轉載,記得給我版權哦.嘿嘿?。。。韵滦畔⑹蔷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
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 马龙县| 烟台市| 台中县| 犍为县| 南京市| 大余县| 五寨县| 朝阳市| 临沧市| 怀柔区| 绩溪县| 阿合奇县| 武汉市| 蒙城县| 云梦县| 潜江市| 太谷县| 陈巴尔虎旗| 同江市| 抚宁县| 扬中市| 林口县| 鲜城| 天峨县| 利津县| 吴堡县| 雅江县| 榆树市| 化隆| 扬州市| 泸溪县| 高安市| 双鸭山市| 安福县| 集安市| 永康市| 绥德县| 鄢陵县| 容城县| 平邑县| 葵青区|