ASP.NET备份数据与还原数据,解决数据库正在使用的问题

 

 备份:
在备份按钮里写:

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   



以上代码的存储过程是建立数据库master中,必须有master数据的操作权限,否则无效。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值