设为首页 收藏本站
查看: 644|回复: 0

[经验分享] C#实现SQL SERVER数据库备份的两种方法比较

[复制链接]

尚未签到

发表于 2016-11-7 09:31:56 | 显示全部楼层 |阅读模式
  先把代码贴上吧
  
  using System;using System.Collections.Generic;using System.Text;using System.Data.SqlClient;using System.Data;using System.Windows.Forms;namespace DBAdmin{public class DbBackUpAndRestore{/// <summary>/// 服务器/// </summary>private string server = "";public string Server{get { return this.server; }set { this.server = value; }}/// <summary>/// 登录名/// </summary>private string uid = "";public string UID{get { return this.uid; }set { this.uid = value; }}/// <summary>/// 登录密码/// </summary>private string pwd = "";public string PWD{get { return this.pwd; }set { this.pwd = value; }}/// <summary>/// 要操作的数据库/// </summary>private string database = "";public string Database{get { return this.database; }set { this.database = value; }}/// <summary>/// 数据库连接字符串/// </summary>private string conn = "";/// <summary>/// 备份路经/// </summary>private string backPath = "";public string BackPath{get { return this.backPath; }set { this.backPath = value; }}/// <summary>/// 还原文件路经/// </summary>private string restoreFile = "";public string RestoreFile{get { return this.restoreFile; }set { this.restoreFile = value; }}private ProgressBar bar;public ProgressBar Bar{get { return bar; }set { bar = value; }}/// <summary>/// DbBackUpAndRestore类的构造函数/// </summary>public DbBackUpAndRestore(){}/// <summary>/// 切割字符串/// </summary>/// <param name="str"></param>/// <param name="bg"></param>/// <param name="ed"></param>/// <returns></returns>public string StringCut(string str, string bg, string ed){string sub;sub = str.Substring(str.IndexOf(bg) + bg.Length);sub = sub.Substring(0, sub.IndexOf(";"));return sub;}/// <summary>/// 构造文件名/// </summary>/// <returns>文件名</returns>private void CreatePath(){string CurrTime = System.DateTime.Now.ToString();CurrTime = CurrTime.Replace("-", "");CurrTime = CurrTime.Replace(":", "");CurrTime = CurrTime.Replace(" ", "");CurrTime = CurrTime.Substring(0, 12);backPath += "//_db_" + CurrTime + ".BAK";}private void Step(string message, int percent){Bar.Value = percent;}/// <summary>/// 数据库备份/// </summary>/// <returns>备份是否成功</returns>public bool DbBackup(){CreatePath();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;SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);oBackup.PercentComplete += pceh;oBackup.Database = database;oBackup.Files = backPath;oBackup.BackupSetName = database;oBackup.BackupSetDescription = "数据库备份";oBackup.Initialize = true;oBackup.SQLBackup(oSQLServer);return true;}catch (Exception ex){return false;throw ex;}finally{oSQLServer.DisConnect();}}/// <summary>/// 数据库恢复/// </summary>public string DbRestore(){if (exepro() != true){return "操作失败";}else{SQLDMO.Restore oRestore = new SQLDMO.RestoreClass();SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();try{exepro();oSQLServer.LoginSecure = false;oSQLServer.Connect(server, uid, pwd);oRestore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;SQLDMO.RestoreSink_PercentCompleteEventHandler pceh = new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);oRestore.PercentComplete += pceh;oRestore.Database = database;///自行修改oRestore.Files = restoreFile;oRestore.FileNumber = 1;oRestore.ReplaceDatabase = true;oRestore.SQLRestore(oSQLServer);return "数据库恢复成功";}catch (Exception e){return "恢复数据库失败,原因:" + e.Message;throw e;}finally{oSQLServer.DisConnect();}}}/// <summary>/// 杀死当前库的所有进程/// </summary>/// <returns></returns>private bool exepro(){bool success = true;SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass();try{svr.Connect(server, uid, pwd);//取得所有的进程列表SQLDMO.QueryResults qr = svr.EnumProcesses(-1);int iColPIDNum = -1;int iColDbName = -1;//找到和要恢复数据库相关的进程for (int i = 1; i <= qr.Columns; i++){string strName = qr.get_ColumnName(i);if (strName.ToUpper().Trim() == "SPID"){iColPIDNum = i;}else if (strName.ToUpper().Trim() == "DBNAME"){iColDbName = i;}if (iColPIDNum != -1 && iColDbName != -1)break;}//将相关进程关闭   for (int i = 1; i <= qr.Rows; i++){int lPID = qr.GetColumnLong(i, iColPIDNum);string strDBName = qr.GetColumnString(i, iColDbName);if (strDBName.ToUpper() == database)svr.KillProcess(lPID);}}catch (Exception ex){success = false;}return success;}public bool Operate(bool isBackup){//备份:use master;backup database @name to disk=@path;//恢复:use master;restore database @name from disk=@path; SqlConnection connection = new SqlConnection("Data Source=" + server + ";initial catalog=" + database + ";user id=" + uid + ";password=" + pwd + ";");if (!restoreFile.EndsWith(".bak")){restoreFile += ".bak";}if (isBackup)//备份数据库 {SqlCommand command = new SqlCommand("use master;backup database @name to disk=@path;", connection);connection.Open();command.Parameters.AddWithValue("@name", Database);command.Parameters.AddWithValue("@path", restoreFile);command.ExecuteNonQuery();connection.Close();}else//恢复数据库 {SqlCommand command = new SqlCommand("use master;restore database @name from disk=@path;", connection);connection.Open();command.Parameters.AddWithValue("@name", Database);command.Parameters.AddWithValue("@path", restoreFile);command.ExecuteNonQuery();connection.Close();}return true;}}}
  
  第一种方法是利用库SQLDMO来进行数据库的备份和恢复。这种方法在恢复时,原数据不能正在使用当中,可以先把原数据库删除,适用于数据库误删除或者sql server数据库软件重装的情况下进行.当然这种情况下,发布时,必须把库SQLDMO打包。
  
  第二种方式是通过调用sql指令来完成数据库的备份和还原。这种方法在恢复时,原数据必须存在,恢复时覆盖掉原数据库的数据。
  
  备份的情况当然是数据库必须存在而且已经附加到数据库管理器中。
  
  可以根据需要采用这两种方式

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-296866-1-1.html 上篇帖子: Server Push Flex4+LCDS3.1 下篇帖子: Tomcat连接池(server.xml)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表