C#数据库备份及还原

1.在用户的配置时,我们需要列出当前局域网内所有的数据库服务器,并且要列出指定服务器的所有数据库,实现代码如下:

取得数据库服务器列表:

  1. public ArrayList GetServerList()
  2. {
  3. ArrayList alServers = new ArrayList() ;
  4. SQLDMO.Application sqlApp = new SQLDMO.ApplicationClass() ;
  5. try
  6. {
  7. SQLDMO.NameList serverList = sqlApp.ListAvailableSQLServers() ;
  8. for(int i = 1;i<= serverList.Count;i++)
  9. {
  10. alServers.Add(serverList.Item(i)) ;
  11. }
  12. }
  13. catch(Exception e)
  14. {
  15. throw(new Exception("取数据库服务器列表出错:"+e.Message)) ;
  16. }
  17. finally
  18. {
  19. sqlApp.Quit() ;
  20. }
  21. return alServers ;
  22. }
 
取得指定数据库服务器的数据库列表   
  1. public ArrayList GetDbList(string strServerName,string strUserName,string strPwd)
  2. {
  3. ServerName = strServerName ;
  4. UserName = strUserName ;
  5. Password = strPwd ;
  6. ArrayList alDbs = new ArrayList() ;
  7. SQLDMO.Application sqlApp = new SQLDMO.ApplicationClass() ;
  8. SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass() ;
  9. try
  10. {
  11. svr.Connect(ServerName,UserName,Password) ;
  12. foreach(SQLDMO.Database db in svr.Databases)
  13. {
  14. if(db.Name!=null)
  15. alDbs.Add(db.Name) ;
  16. }
  17. }
  18. catch(Exception e)
  19. {
  20. throw(new Exception("连接数据库出错:"+e.Message)) ;
  21. }
  22. finally
  23. {
  24. svr.DisConnect() ;
  25. sqlApp.Quit() ;
  26. }
  27. return alDbs ;
  28. }
 

2.数据库的备份和实时进度显示代码:

  1. public bool BackUPDB(string strDbName,string strFileName, ProgressBar pgbMain)
  2. {
  3. PBar = pgbMain ;
  4. SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass() ;
  5. try
  6. {
  7. svr.Connect(ServerName,UserName,Password) ;
  8. SQLDMO.Backup bak = new SQLDMO.BackupClass();
  9. bak.Action =  ;
  10. bak.Initialize = true ;
  11. SQLDMO.BackupSink_PercentCompleteEventHandler pceh =
  12. new SQLDMO.BackupSink_PercentCompleteEventHandler(Step);
  13. bak.PercentComplete += pceh;
  14. bak.Files = strFileName;
  15. bak.Database = strDbName;
  16. bak.SQLBackup(svr);
  17. return true ;
  18. }
  19. catch(Exception err)
  20. {
  21. throw(new Exception("备份数据库失败"+err.Message)) ;
  22. }
  23. finally
  24. {
  25. svr.DisConnect() ;
  26. }
  27. }
  28. private void Step(string message,int percent)
  29. {
  30. PBar.Value = percent ;
  31. }

其中,这两个语句实现了进度的实时显示:

SQLDMO.BackupSink_PercentCompleteEventHandler pceh = new     SQLDMO.BackupSink_PercentCompleteEventHandler(Step); 
    bak.PercentComplete += pceh;

Step就是上面private void Step(string message,int percent) 的方法名称,它用来显示进度条的当前进度。

3.数据库的恢复和杀死进程的代码:

  1. public bool RestoreDB(string strDbName,string strFileName, ProgressBar pgbMain)
  2. {
  3. PBar = pgbMain ;
  4. SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass() ;
  5. try
  6. {
  7. svr.Connect(ServerName,UserName,Password) ;
  8. SQLDMO.QueryResults qr = svr.EnumProcesses(-1) ;
  9. int iColPIDNum = -1 ;
  10. int iColDbName = -1 ;
  11. for(int i=1;i<=qr.Columns;i++)
  12. {
  13. string strName = qr.get_ColumnName(i) ;
  14. if (strName.ToUpper().Trim() == "SPID")
  15. {
  16. iColPIDNum = i ;
  17. }
  18. else if (strName.ToUpper().Trim() == "DBNAME")
  19. {
  20. iColDbName = i ;
  21. }
  22. if (iColPIDNum != -1 && iColDbName != -1)
  23. break ;
  24. }
  25. for(int i=1;i<=qr.Rows;i++)
  26. {
  27. int lPID = qr.GetColumnLong(i,iColPIDNum) ;
  28. string strDBName = qr.GetColumnString(i,iColDbName) ;
  29. if (strDBName.ToUpper() == strDbName.ToUpper())
  30. svr.KillProcess(lPID) ;
  31. }
  32. SQLDMO.Restore res = new SQLDMO.RestoreClass() ;
  33. res.Action = 0 ;
  34. SQLDMO.RestoreSink_PercentCompleteEventHandler pceh =
  35. new SQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
  36. res.PercentComplete += pceh;
  37. res.Files = strFileName ;
  38. res.Database = strDbName ;
  39. res.ReplaceDatabase = true ;
  40. res.SQLRestore(svr) ;
  41. return true ;
  42. }
  43. catch(Exception err)
  44. {
  45. throw(new Exception("恢复数据库失败,请关闭所有和该数据库连接的程序!"+err.Message)) ;
  46. }
  47. finally
  48. {
  49. svr.DisConnect() ;
  50. }
  51. }

其中这个语句取得了所有的进程列表:

SQLDMO.QueryResults qr = svr.EnumProcesses(-1) ;

下面的语句找到和要恢复数据库相关的进程并杀死:

  1. int iColPIDNum = -1 ;
  2. int iColDbName = -1 ;
  3. for(int i=1;i<=qr.Columns;i++)
  4. {
  5. string strName = qr.get_ColumnName(i) ;
  6. if (strName.ToUpper().Trim() == "SPID")
  7. {
  8. iColPIDNum = i ;
  9. }
  10. else if (strName.ToUpper().Trim() == "DBNAME")
  11. {
  12. iColDbName = i ;
  13. }
  14. if (iColPIDNum != -1 && iColDbName != -1)
  15. break ;
  16. }
  17. for(int i=1;i<=qr.Rows;i++)
  18. {
  19. int lPID = qr.GetColumnLong(i,iColPIDNum) ;
  20. string strDBName = qr.GetColumnString(i,iColDbName) ;
  21. if (strDBName.ToUpper() == strDbName.ToUpper())
  22. svr.KillProcess(lPID) ;
  23. }

 C#数据库备份及还原就介绍到这里,希望对你有所帮助。

/////////////////////////////////////////////////////

利用C#还原数据库(SQL SERVER)备份文件到指定路径

利用C#还原数据库(SQL SERVER)备份文件到指定路径

2012-2-19 08:58| 发布者: benben| 查看: 1938| 评论: 0

 
摘要:   最近在做一个数据采集模块,遇到这样一个场景,就是需要将数据库备份文件还原到指定数据库实例下再采集数据。本机测试都没有问题,可一拿到真实环境中测试却发现了一个很大的Bug。所有的数据库都还原不上,很纠 ...
 
 

  最近在做一个数据采集模块,遇到这样一个场景,就是需要将数据库备份文件还原到指定数据库实例下再采集数据。本机测试都没有问题,可一拿到真实环境中测试却发现了一个很大的Bug。所有的数据库都还原不上,很纠结。因为我本以为SQL SERVER 会还原到默认路径下,其实不然。

  当我拿到真实数据库备份文件时,我首先在数据库中运行 restore database RestoreDbName from disk ='H:\DBFolder\Db_Back' ,执行结果如下:

  

  到现在我依然不知道是怎么回事,因为我自己创建的数据库再还原是好使的。怎么会这样?一个意外让我发现原来我建的数据库是在数据库实例默认的路径下,而真实数据库备份文件则不是,它的路径是客户机器上的,肯定不一样。为了验证这个发现,我做了如下的工作。

第一步:创建数据库,create database TestDb 。

第二步:备份数据库。

第三步:直接还原数据库,restore database RestoreDbName from disk ='I:\TestDatabase'  ,执行成功。

第四步:还原数据库,这时候我不是采用默认还原,而是将数据库还原到系统的另一个路径下,代码如下:

restore database RestoreDbName from disk ='I:\TestDatabase'   with  replace, move 'TestDb' to 'H:\DBFolder\RestoreDbName_Data.mdf', move 'TestDb_log' to 'H:\DBFolder\RestoreDbName_Log.ldf'

执行结果:

  第五步:再次备份数据库RestoreDbName。备份后我们用 filelistonly 可以看到当前数据库备份文件的备份路径( restore filelistonly from disk = 'I:\RestoreDb' ), 执行后结果如下:

  从这里我们可以看到当前数据库备份文件的真实物理路径。

第六步:当我再次执行 restore database RestoreDbName from disk ='I:\RestoreDb' ,执行错误。出现了和真实环境一样的错误。原来如上文所述那样,数据库备份文件在还原时,如果当前数据库实例的默认路径和数据库备份文件不相符时需要通过move来解决,而不能单纯的 Restore。

于是我又重新写了一下数据库备份文件还原的相关方法,如下所示。通过这个方法就能简单的实现数据库备份文件还原了。

 /// <summary>
/// 还原数据库文件
/// </summary>
/// <param name="basePath">电子账簿所在根目录</param>
/// <param name="fileName">数据库备份文件名称</param>
/// <param name="databaseName">需要还原的数据库名称</param>
/// <param name="conn">数据库连接</param>
private bool RestoreDataBase(string basePath, string fileName, string databaseName, SqlConnection conn)
{
SqlCommand command = null;
try
{
string restoreStr = string.Empty;
string getLogicFileName = string.Format("restore filelistonly from disk ='{0}'", Path.Combine(basePath, fileName));
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter(getLogicFileName, conn);
da.Fill(ds);
if (ds.Tables == null || ds.Tables[0].Rows.Count == 0) return false; foreach (DataRow dr in ds.Tables[0].Rows)
{
//查找数据库逻辑文件名称
if ("D".Equals(dr["Type"].ToString()))
restoreStr += string.Format("move '{0}' to '{1}',", dr["LogicalName"].ToString(), Path.Combine(basePath, databaseName) + "_Data.mdf");
//查找数据库日志文件名称
else if ("L".Equals(dr["Type"].ToString()))
restoreStr += string.Format("move '{0}' to '{1}',", dr["LogicalName"].ToString(), Path.Combine(basePath, databaseName) + "_Log.ldf");
}
if (string.IsNullOrEmpty(restoreStr))
restoreStr = string.Format("restore database {0} from disk ='{1}'", databaseName, Path.Combine(basePath, fileName));
else
{
restoreStr = string.Format("restore database {0} from disk ='{1}' with replace,", databaseName, Path.Combine(basePath, fileName)) + restoreStr.TrimEnd(',');
}
command = new SqlCommand(restoreStr, conn);
conn.Open();
command.ExecuteNonQuery();
return true;
}
catch (Exception ex)
{
return false;
}
finally
{
conn.Close();
}
}
/// <summary>
/// 还原数据库文件
/// </summary>
/// <param name="basePath">电子账簿所在根目录</param>
/// <param name="fileName">数据库备份文件名称</param>
/// <param name="databaseName">需要还原的数据库名称</param>
/// <param name="conn">数据库连接</param>
private bool RestoreDataBase(string basePath, string fileName, string databaseName, SqlConnection conn)
{
SqlCommand command = null;
try
{
string restoreStr = string.Empty;
string getLogicFileName = string.Format("restore filelistonly from disk ='{0}'", Path.Combine(basePath, fileName));
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter(getLogicFileName, conn);
da.Fill(ds);
if (ds.Tables == null || ds.Tables[0].Rows.Count == 0) return false; foreach (DataRow dr in ds.Tables[0].Rows)
{
//查找数据库逻辑文件名称
if ("D".Equals(dr["Type"].ToString()))
restoreStr += string.Format("move '{0}' to '{1}',", dr["LogicalName"].ToString(), Path.Combine(basePath, databaseName) + "_Data.mdf");
//查找数据库日志文件名称
else if ("L".Equals(dr["Type"].ToString()))
restoreStr += string.Format("move '{0}' to '{1}',", dr["LogicalName"].ToString(), Path.Combine(basePath, databaseName) + "_Log.ldf");
}
if (string.IsNullOrEmpty(restoreStr))
restoreStr = string.Format("restore database {0} from disk ='{1}'", databaseName, Path.Combine(basePath, fileName));
else
{
restoreStr = string.Format("restore database {0} from disk ='{1}' with replace,", databaseName, Path.Combine(basePath, fileName)) + restoreStr.TrimEnd(',');
}
command = new SqlCommand(restoreStr, conn);
conn.Open();
command.ExecuteNonQuery();
return true;
}
catch (Exception ex)
{
return false;
}
finally
{
conn.Close();
}
}

C#备份及还原数据库的实现代码(粗略) // 利用C#还原数据库(SQL SERVER)备份文件到指定路径的更多相关文章

  1. python:利用pymssql模块操作SQL server数据库

    python默认的数据库是 SQLlite,不过它对MySql以及SQL server的支持也可以.这篇博客,介绍下如何在Windows下安装pymssql库并进行连接使用... 环境:Windows ...

  2. SQL 数据库 学习 003 什么是数据库? 为什么需要数据库?是不是所有的软件都是用Sql Server?

    什么是数据库? 为什么需要数据库? 是不是所有的软件都是用Sql Server? 我的电脑系统: Windows 10 64位 使用的SQL Server软件: SQL Server 2014 Exp ...

  3. 功能齐全、效率一流的免费开源数据库导入导出工具(c#开发,支持SQL server、SQLite、ACCESS三种数据库),每月借此处理数据5G以上

    软件名:DataPie 功能:支持SQL server.SQLite.ACCESS数据库的导入.导出.存储过程调用,支持EXCEL2007.EXCEL2003.ACCESS2007. CSV文件导入数 ...

  4. PHP连接MSSQL数据库案例,PHPWAMP多个PHP版本连接SQL Server数据库

    课前小知识普及:MSSQL和SQL Server是同一个软件,叫法不同而已,MSSQL全称是Microsoft SQL Server,MSSQL是简写,有些人则喜欢直接叫SQL Server,我就比较 ...

  5. 【转发】PHP连接MSSQL数据库案例,PHPWAMP多个PHP版本连接SQL Server数据库

    转发自:http://blog.csdn.net/lccee/article/details/54289076 课前小知识普及:MSSQL和SQL Server是同一个软件,叫法不同而已,MSSQL全 ...

  6. 小麦苗数据库巡检脚本,支持Oracle、MySQL、SQL Server和PG等数据库

    目录 一.巡检脚本简介 二.巡检脚本特点 三.巡检结果展示 1.Oracle数据库 2.MySQL数据库 3.SQL Server数据库 4.PG数据库 5.OS信息 四.脚本运行方式 1.Oracl ...

  7. 数据库批量修改表名,增加前缀(SQL server)

    exec sp_msforeachtable @command1=' declare @o sysname,@n sysname select @o=''?'' ,@n=stuff(@o,1,7,'' ...

  8. Sql Server 备份还原失败错误ERROR:3145(备份集中的数据库备份与现有的数据库不同)及解决办法

    SQL Server备份文件bak,备份后还原出现错误3145,备份集中的数据库备份与现有的 'xxx' 数据库不同. 解决办法如下: 1,新建一个与现有数据库重名的数据库. 如果您不知道数据库名称, ...

  9. 数据库开发基础 SQL Server 数据库的备份、还原与分离、附加

    认识数据库备份和事务日志备份 数据库备份与日志备份是数据库维护的日常工作,备份的目的是 一.在于当数据库出现故障或者遭到破坏时可以根据备份的数据库及事务日志文件还原到最近的时间点将损失降到最低点 二. ...

随机推荐

  1. Python 时间处理---------笔记

    时区处理&格式化 import pytz from datetime import datetime # 设置时区 timezone = pytz.timezone('Asia/Shangha ...

  2. [系统]no such partition

    电脑系统是win8.1+ubuntu14.2,为了卸载ubuntu,安装CentOS,于是在win8.1下把ubuntu的分区给删除了,重启,出现no such partition grub resc ...

  3. ZfNet解卷积:可视化CNN模型( PythonCode可视化Cifar10)

    原文链接:caffe Model的可视化 snapshot: 6000       一个在线可视化小工具:http://blog.csdn.net/10km/article/details/52713 ...

  4. JAVA趣味逻辑算法

    /**已知4位同学中的一位数学考了100分,当小李询问这4位是谁考了100分时,4个人的回答如下: A说:不是我. B说:是C C说:是D. D说:他胡说. 已知三个人说的是真话,一个人说的是假话.现 ...

  5. 【VHDL】深度讲解二进制无符号和有符号加法处理溢出的问题

    1.Unsigned adders 这个比较简单,只需在A.B前面扩展一位0防止溢出,溢出的数填到第n位cout,n-1到0位就是sum. , 2.Signed adders 一开始也搞不懂下图中为什 ...

  6. Ubuntu 关闭guest用户

    Ubuntu 关闭guest用户 ca0gu0@ub:~$ cat /etc/lightdm/lightdm.conf [SeatDefaults]autologin-user=falseallow- ...

  7. (转) 分布式文件存储FastDFS(七)FastDFS配置文件详解

    http://blog.csdn.net/xingjiarong/article/details/50752586 配置FastDFS时,修改配置文件是很重要的一个步骤,理解配置文件中每一项的意义更加 ...

  8. python合并多个txt文件成为一个文件

    #coding=utf-8 import os import os.path #文件夹遍历函数 #获取目标文件夹的路径 filedir = './data/click_data' #获取当前文件夹中的 ...

  9. 洛谷——P2574 XOR的艺术

    P2574 XOR的艺术 很久之前就想挑战一下这道题了,线段树下传标记的入门题,跟区间加法下传标记类似. #include<bits/stdc++.h> #define N 1000005 ...

  10. 非递归全排列 python实现

    python algorithm 全排列(Permutation) 排列(英语:Permutation)是将相异物件或符号根据确定的顺序重排.每个顺序都称作一个排列.例如,从一到六的数字有720种排列 ...