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

用ASP.NET還原與恢復(fù)Sql server

  上次做了個(gè)項(xiàng)目,涉及到數(shù)據(jù)庫(kù)的還原和恢復(fù),到網(wǎng)上找了一下,是利用SQLDMO實(shí)現(xiàn)的,只要添加SQLDMO引用就好了,然后利用下邊的類的方法就可以實(shí)現(xiàn)了。

  我把原作者的類擴(kuò)充了一下,可以自動(dòng)識(shí)別web.config里 的數(shù)據(jù)庫(kù)連接字符串,可以通過變量設(shè)置還原恢復(fù)的信息。

  需要注意的時(shí)還原,還原的時(shí)候問題最大了,有別的用戶使用數(shù)據(jù)庫(kù)的時(shí)候無法還原,解決辦法就是在MASTER數(shù)據(jù)庫(kù)中添加一個(gè)存儲(chǔ)過程:

  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 GO

  在還原之前先執(zhí)行這個(gè)存儲(chǔ)過程,需要傳遞dbname,就是你的數(shù)據(jù)庫(kù)的名字。下邊是類的原代碼:(web.config里的數(shù)據(jù)庫(kù)連接字符串是constr)

    using System;
    using System.Configuration;
    using System.Data.SqlClient;
    using System.Data;
    namespace web.base_class
    ...{
    /**////
     /// DbOper類,主要應(yīng)用SQLDMO實(shí)現(xiàn)對(duì)Microsoft SQL Server數(shù)據(jù)庫(kù)的備份和恢復(fù)
    ///
     public class DbOper
    ...{
    private string server;
    private string uid;
    private string pwd;
    private string database;
    private string conn;
    /**////
     /// DbOper類的構(gòu)造函數(shù)
    ///
     public DbOper()
    ...{
    conn=System.Configuration.ConfigurationSettings.AppSettings["constr"].ToString();    server=cut(conn,"server=",";");
    uid=cut(conn,"uid=",";");
    pwd=cut(conn,"pwd=",";");
    database=cut(conn,"database=",";");
    }
   public string cut(string str,string bg,string ed)
    ...{
    string sub;
    sub=str.Substring(str.IndexOf(bg)+bg.Length);
    sub=sub.Substring(0,sub.IndexOf(";"));
    return sub;
    }
   /**////
     /// 數(shù)據(jù)庫(kù)備份
    ///
     public bool DbBackup(string url)
    ...{    SQLDMO.Backup oBackup = new SQLDMO.BackupClass();
    SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
    try
    ...{
    oSQLServer.LoginSecure = false;
    oSQLServer.Connect(server,uid, pwd);
    oBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
    oBackup.Database = database;
    oBackup.Files = url;//"d:/Northwind.bak";
    oBackup.BackupSetName = database;
    oBackup.BackupSetDescription = "數(shù)據(jù)庫(kù)備份";    oBackup.Initialize = true;    oBackup.SQLBackup(oSQLServer);
    return true;
    }
   catch
    ...{
    return false;
    throw;
    }
   finally
   ...{
    oSQLServer.DisConnect();
    }
   }
///數(shù)據(jù)庫(kù)恢復(fù) ///
  public string DbRestore(string url)
 { if(exepro()!=true)
//執(zhí)行存儲(chǔ)過程 { return "操作失敗"; }
else { SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();
 SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
 try { oSQLServer.LoginSecure = false; oSQLServer.Connect(server, uid, pwd);
 oRestore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
 oRestore.Database = database;
 oRestore.Files = url;
//@"d:/Northwind.bak";
 oRestore.FileNumber = 1;
 oRestore.ReplaceDatabase = true;
 oRestore.SQLRestore(oSQLServer);
 return "ok"; } catch(Exception e)
 { return "恢復(fù)數(shù)據(jù)庫(kù)失敗";
 throw;
 } finally { oSQLServer.DisConnect();
 } } }
    private bool exepro()
 { SqlConnection conn1 = new SqlConnection("server="+server+";uid="+uid+";pwd="+pwd+";database=master");
 SqlCommand cmd = new SqlCommand("killspid",conn1);
 cmd.CommandType = CommandType.StoredProcedure;
 cmd.Parameters.Add("@dbname","port");
 try { conn1.Open();
 cmd.ExecuteNonQuery();
 return true;
 }
catch(Exception ex)
 { return false;
 } finally
 {
conn1.Close();
 }
}
}
}

AspNet技術(shù)用ASP.NET還原與恢復(fù)Sql server,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线播放成人无码日 | 亚洲AV日韩AV欧美在线观看网 | 免费女人光着全身网站 | 麻豆啊传媒app黄版破解免费 | 久久精品中文字幕 | 99视频精品在线 | 中文字幕爆乳JULIA女教师 | 久久精品无码成人国产毛 | 寂寞骚妇女被后入式抽插 | 久草在在线免视频在线观看 | 虫族bl文全肉高h | 国产精品96久久久久久AV网址 | 后入式狂顶免费视频 | 99爱在线精品视频网站 | 亚洲大码熟女在线 | 三级黄色在线免费观看 | 男污女XO猛烈的动态图 | 亚洲性无码AV久久成人 | 亚洲一区综合图区 | 成人中文在线 | 调教美丽的白丝袜麻麻视频 | 亚洲人成77777在线视频 | 国产精品一久久香蕉国产线看 | 中文字幕无码乱人伦蜜桃 | 欧美性黑吊xxx | 一二三四在线视频社区 | 最近在线视频观看2018免费 | 叔叔 电影完整版免费观看韩国 | 日本中文字幕伊人成中文字幕 | 无码日韩人妻精品久久蜜桃入口 | 亚洲AV无码影院在线播放 | 久久人妻少妇嫩草AV无码 | 亚洲免费无l码中文在线视频 | 99久久99久久久精品齐齐鬼色 | 国产成人永久免费视频 | 国产精品人成视频免费999 | 999zyz色资源站在线观看 | 最近2018年手机中文字幕 | 日本熟妇乱妇熟色A片蜜桃亚洲 | 国家产午夜精品无人区 | 德国美女密密麻麻浓毛 |