asp.net 因为数据库正在使用的解决方法 |
本文标签: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 |