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

首頁(yè) > 編程 > .NET > 正文

asp.net 因?yàn)閿?shù)據(jù)庫(kù)正在使用的解決方法

2024-07-10 13:20:53
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這個(gè)問(wèn)題困惑我好長(zhǎng)的時(shí)間,在網(wǎng)上搜,也沒(méi)完全的解決方案,不是過(guò)于簡(jiǎn)單,就是亂說(shuō),有的論壇上還沒(méi)人回答這個(gè)問(wèn)題.今天我徹底解決這個(gè)問(wèn)題,并在C#里測(cè)試完全通過(guò).現(xiàn)在把他寫(xiě)出來(lái),希望對(duì)朋友們有幫助(如要轉(zhuǎn)載,記得給我版權(quán)哦.嘿嘿!!!).以下信息是綜合網(wǎng)上的資料和我的實(shí)際問(wèn)題,整理出來(lái)的.
備份:
在備份按鈕里寫(xiě):

復(fù)制代碼 代碼如下:


protected void Button1_Click(object sender, EventArgs e)
{
string path = "e://MAZ數(shù)據(jù)庫(kù)備份//" + Menu+ ".bak";
if (File.Exists(path))
{
File.Delete(path);//注意,這個(gè)步驟很重要,如果重復(fù),在備份的數(shù)據(jù),就會(huì)變成,

//你剛開(kāi)始的數(shù)據(jù),所以每次都要先刪除.

      }
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();
}
}


還原:
在還原按鈕里寫(xiě):

復(fù)制代碼 代碼如下:


protected void Button2_Click(object sender, EventArgs e)
{
string path = "e://MAZ數(shù)據(jù)庫(kù)備份//" + 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+ "'";//這個(gè)很關(guān)鍵,要不然就出現(xiàn)題目上的錯(cuò)誤了
SqlCommand cmd = new SqlCommand(sql, connection);
connection.Open();

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


}


存儲(chǔ)過(guò)程 killspid

復(fù)制代碼 代碼如下:


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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 峨眉山市| 吉林市| 高雄市| 封开县| 南木林县| 攀枝花市| 那曲县| 奉贤区| 昌江| 略阳县| 昔阳县| 循化| 崇左市| 湛江市| 麻阳| 大冶市| 宁化县| 新兴县| 定南县| 曲沃县| 阿拉善右旗| 丘北县| 灵川县| 洛南县| 宜兰市| 宿松县| 马尔康县| 清河县| 庆云县| 宁化县| 阿拉善右旗| 邹城市| 九龙城区| 临汾市| 隆尧县| 繁昌县| 泾川县| 虎林市| 永州市| 舟曲县| 宜兰市|