C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)

本文主要是介绍C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. C#实现SQLSERVER2000数据库备份还原的两种方法
  2. :方法一(不使用SQLDMO):
  3. ///
  4. ///备份方法
  5. ///
  6. SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;");
  7. SqlCommandcmdBK=newSqlCommand();
  8. cmdBK.CommandType=CommandType.Text;
  9. cmdBK.Connection=conn;
  10. cmdBK.CommandText=@"backupdatabasetesttodisk='C:/ba'withinit";
  11. try
  12. {
  13. conn.Open();
  14. cmdBK.ExecuteNonQuery();
  15. MessageBox.Show("Backupsuccessed.");
  16. }
  17. catch(Exceptionex)
  18. {
  19. MessageBox.Show(ex.Message);
  20. }
  21. finally
  22. {
  23. conn.Close();
  24. conn.Dispose();
  25. }
  26. ///
  27. ///还原方法
  28. ///
  29. SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;Trusted_Connection=False");
  30. conn.Open();
  31. //KILLDataBaseProcess
  32. SqlCommandcmd=newSqlCommand("SELECTspidFROMsysprocesses,sysdatabasesWHEREsysprocesses.dbid=sysdatabases.dbidANDsysdatabases.Name='test'",conn);
  33. SqlDataReaderdr;
  34. dr=cmd.ExecuteReader();
  35. ArrayListlist=newArrayList();
  36. while(dr.Read())
  37. {
  38. list.Add(dr.GetInt16(0));
  39. }
  40. dr.Close();
  41. for(inti=0;i<list.Count;i++)
  42. {
  43. cmd=newSqlCommand(string.Format("KILL{0}",list),conn);
  44. cmd.ExecuteNonQuery();
  45. }
  46. SqlCommandcmdRT=newSqlCommand();
  47. cmdRT.CommandType=CommandType.Text;
  48. cmdRT.Connection=conn;
  49. cmdRT.CommandText=@"restoredatabasetestfromdisk='C:/ba'";
  50. try
  51. {
  52. cmdRT.ExecuteNonQuery();
  53. MessageBox.Show("Restoresuccessed.");
  54. }
  55. catch(Exceptionex)
  56. {
  57. MessageBox.Show(ex.Message);
  58. }
  59. finally
  60. {
  61. conn.Close();
  62. }
  63. 方法二(使用SQLDMO):
  64. ///
  65. ///备份方法
  66. ///
  67. SQLDMO.Backupbackup=newSQLDMO.BackupClass();
  68. SQLDMO.SQLServerserver=newSQLDMO.SQLServerClass();
  69. //显示进度条
  70. SQLDMO.BackupSink_PercentCompleteEventHandlerprogress=newSQLDMO.BackupSink_PercentCompleteEventHandler(Step);
  71. backup.PercentComplete+=progress;
  72. try
  73. {
  74. server.LoginSecure=false;
  75. server.Connect(".","sa","sa");
  76. backup.Action=SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
  77. backup.Database="test";
  78. backup.Files=@"D:/test/myProg/backupTest";
  79. backup.BackupSetName="test";
  80. backup.BackupSetDescription="Backupthedatabaseoftest";
  81. backup.Initialize=true;
  82. backup.SQLBackup(server);
  83. MessageBox.Show("Backupsuccessed.");
  84. }
  85. catch(Exceptionex)
  86. {
  87. MessageBox.Show(ex.Message);
  88. }
  89. finally
  90. {
  91. server.DisConnect();
  92. }
  93. this.pbDB.Value=0;
  94. ///
  95. ///还原方法
  96. ///
  97. SQLDMO.Restorerestore=newSQLDMO.RestoreClass();
  98. SQLDMO.SQLServerserver=newSQLDMO.SQLServerClass();
  99. //显示进度条
  100. SQLDMO.RestoreSink_PercentCompleteEventHandlerprogress=newSQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
  101. restore.PercentComplete+=progress;
  102. //KILLDataBaseProcess
  103. SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;Trusted_Connection=False");
  104. conn.Open();
  105. SqlCommandcmd=newSqlCommand("SELECTspidFROMsysprocesses,sysdatabasesWHEREsysprocesses.dbid=sysdatabases.dbidANDsysdatabases.Name='test'",conn);
  106. SqlDataReaderdr;
  107. dr=cmd.ExecuteReader();
  108. ArrayListlist=newArrayList();
  109. while(dr.Read())
  110. {
  111. list.Add(dr.GetInt16(0));
  112. }
  113. dr.Close();
  114. for(inti=0;i<list.Count;i++)
  115. {
  116. cmd=newSqlCommand(string.Format("KILL{0}",list),conn);
  117. cmd.ExecuteNonQuery();
  118. }
  119. conn.Close();
  120. try
  121. {
  122. server.LoginSecure=false;
  123. server.Connect(".","sa","sa");
  124. restore.Action=SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
  125. restore.Database="test";
  126. restore.Files=@"D:/test/myProg/backupTest";
  127. restore.FileNumber=1;
  128. restore.ReplaceDatabase=true;
  129. restore.SQLRestore(server);
  130. MessageBox.Show("Restoresuccessed.");
  131. }
  132. catch(Exceptionex)
  133. {
  134. MessageBox.Show(ex.Message);
  135. }
  136. finally
  137. {
  138. server.DisConnect();
  139. }
  140. this.pbDB.Value=0;

这篇关于C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/472887

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

SpringBoot+EasyPOI轻松实现Excel和Word导出PDF

《SpringBoot+EasyPOI轻松实现Excel和Word导出PDF》在企业级开发中,将Excel和Word文档导出为PDF是常见需求,本文将结合​​EasyPOI和​​Aspose系列工具实... 目录一、环境准备与依赖配置1.1 方案选型1.2 依赖配置(商业库方案)二、Excel 导出 PDF

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法