[整理] C#调用SQLDMO.DLL时间数据库备份 / 还原。 (香神无涯) // C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)...
/// <summary>
/// 通过调用MSSQL的SQLDMO.DLL文件来实现备份数据库
/// 1.首先在在项目中引用SQLDMO.DLL文件。
/// 2.在引用中的SQLDMO.DLL文件右击-->属性-->设置[嵌入互操作类型]为flash
/// </summary>
public static void DBBackup()
{
SQLDMO.Backup dbBackup = new SQLDMO.BackupClass();
SQLDMO.SQLServer sqlServer = new SQLDMO.SQLServerClass();
try
{
sqlServer.LoginSecure = false;
sqlServer.Connect("localhost", "sa", "");
dbBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
dbBackup.Database = "kuang"; //数据库名字
dbBackup.Files = @"d:\kuang_bak.bak"; //备份位置
dbBackup.BackupSetName = "kuang"; //名称,在企业管理器里面选择备份的时候也有这个,貌似没用。
dbBackup.BackupSetDescription = "数据库备份"; //描述,在企业管理器里面选择备份的时候也有这个,貌似没用。
dbBackup.Initialize = true;
dbBackup.SQLBackup(sqlServer);
}
catch
{
throw;
}
finally
{
sqlServer.DisConnect();
}
}
/// <summary>
/// 通过调用MSSQL的SQLDMO.DLL文件来实现从备份文件恢复到是数据库
/// 注:恢复是数据库必须是没有链接的。清楚链接的方法:在企业管理器右击数据库-->分离数据库-->点击清楚按钮即可
/// </summary>
private void DBReply()
{
SQLDMO.Restore restore = new SQLDMO.RestoreClass();
SQLDMO.SQLServer sqlserver = new SQLDMO.SQLServerClass();
sqlserver.LoginSecure = false;
sqlserver.Connect("localhost", "sa", "");
restore.Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
restore.Database = "kuang";
restore.Files = @"d:\kuang_bak.bak";
restore.FileNumber = 1;
restore.SQLRestore(sqlserver);
}
在回复的过程中,需要保证数据库没有正在使用,网上看到的代码经测试没有效果,如果有朋友知道方法的恳请您回复一下,谢谢。
代码是网络上看到的,测试整理了一下,感谢原作者。
-------------------------------------------------------------------------------------------
C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)
- C#实现SQLSERVER2000数据库备份还原的两种方法
- :方法一(不使用SQLDMO):
- ///
- ///备份方法
- ///
- SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;");
- SqlCommandcmdBK=newSqlCommand();
- cmdBK.CommandType=CommandType.Text;
- cmdBK.Connection=conn;
- cmdBK.CommandText=@"backupdatabasetesttodisk='C:/ba'withinit";
- try
- {
- conn.Open();
- cmdBK.ExecuteNonQuery();
- MessageBox.Show("Backupsuccessed.");
- }
- catch(Exceptionex)
- {
- MessageBox.Show(ex.Message);
- }
- finally
- {
- conn.Close();
- conn.Dispose();
- }
- ///
- ///还原方法
- ///
- SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;Trusted_Connection=False");
- conn.Open();
- //KILLDataBaseProcess
- SqlCommandcmd=newSqlCommand("SELECTspidFROMsysprocesses,sysdatabasesWHEREsysprocesses.dbid=sysdatabases.dbidANDsysdatabases.Name='test'",conn);
- SqlDataReaderdr;
- dr=cmd.ExecuteReader();
- ArrayListlist=newArrayList();
- while(dr.Read())
- {
- list.Add(dr.GetInt16(0));
- }
- dr.Close();
- for(inti=0;i<list.Count;i++)
- {
- cmd=newSqlCommand(string.Format("KILL{0}",list),conn);
- cmd.ExecuteNonQuery();
- }
- SqlCommandcmdRT=newSqlCommand();
- cmdRT.CommandType=CommandType.Text;
- cmdRT.Connection=conn;
- cmdRT.CommandText=@"restoredatabasetestfromdisk='C:/ba'";
- try
- {
- cmdRT.ExecuteNonQuery();
- MessageBox.Show("Restoresuccessed.");
- }
- catch(Exceptionex)
- {
- MessageBox.Show(ex.Message);
- }
- finally
- {
- conn.Close();
- }
- 方法二(使用SQLDMO):
- ///
- ///备份方法
- ///
- SQLDMO.Backupbackup=newSQLDMO.BackupClass();
- SQLDMO.SQLServerserver=newSQLDMO.SQLServerClass();
- //显示进度条
- SQLDMO.BackupSink_PercentCompleteEventHandlerprogress=newSQLDMO.BackupSink_PercentCompleteEventHandler(Step);
- backup.PercentComplete+=progress;
- try
- {
- server.LoginSecure=false;
- server.Connect(".","sa","sa");
- backup.Action=SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
- backup.Database="test";
- backup.Files=@"D:/test/myProg/backupTest";
- backup.BackupSetName="test";
- backup.BackupSetDescription="Backupthedatabaseoftest";
- backup.Initialize=true;
- backup.SQLBackup(server);
- MessageBox.Show("Backupsuccessed.");
- }
- catch(Exceptionex)
- {
- MessageBox.Show(ex.Message);
- }
- finally
- {
- server.DisConnect();
- }
- this.pbDB.Value=0;
- ///
- ///还原方法
- ///
- SQLDMO.Restorerestore=newSQLDMO.RestoreClass();
- SQLDMO.SQLServerserver=newSQLDMO.SQLServerClass();
- //显示进度条
- SQLDMO.RestoreSink_PercentCompleteEventHandlerprogress=newSQLDMO.RestoreSink_PercentCompleteEventHandler(Step);
- restore.PercentComplete+=progress;
- //KILLDataBaseProcess
- SqlConnectionconn=newSqlConnection("Server=.;Database=master;UserID=sa;Password=sa;Trusted_Connection=False");
- conn.Open();
- SqlCommandcmd=newSqlCommand("SELECTspidFROMsysprocesses,sysdatabasesWHEREsysprocesses.dbid=sysdatabases.dbidANDsysdatabases.Name='test'",conn);
- SqlDataReaderdr;
- dr=cmd.ExecuteReader();
- ArrayListlist=newArrayList();
- while(dr.Read())
- {
- list.Add(dr.GetInt16(0));
- }
- dr.Close();
- for(inti=0;i<list.Count;i++)
- {
- cmd=newSqlCommand(string.Format("KILL{0}",list),conn);
- cmd.ExecuteNonQuery();
- }
- conn.Close();
- try
- {
- server.LoginSecure=false;
- server.Connect(".","sa","sa");
- restore.Action=SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
- restore.Database="test";
- restore.Files=@"D:/test/myProg/backupTest";
- restore.FileNumber=1;
- restore.ReplaceDatabase=true;
- restore.SQLRestore(server);
- MessageBox.Show("Restoresuccessed.");
- }
- catch(Exceptionex)
- {
- MessageBox.Show(ex.Message);
- }
- finally
- {
- server.DisConnect();
- }
- this.pbDB.Value=0;
SQLDMO类的使用
SQLDMO(SQL Distributed Management Objects,SQL分布式管理对象)封装 Microsoft SQL Server 2000 数据库中的对象。SQL-DMO 允许用支持自动化或 COM 的语言编写应用程序,以管理 SQL Server 安装的所有部分。SQL-DMO 是 SQL Server 2000 中的 SQL Server 企业管理器所使用的应用程序接口 (API);因此使用 SQL-DMO 的应用程序可以执行 SQL Server 企业管理器执行的所有功能。
SQL-DMO 用于必须包含 SQL Server 管理的任何自动化或 COM 应用程序,例如:
1.封装 SQL Server 作为自己的数据存储并想尽量减少用户的 SQL Server 管理任务的应用程序。
2.在程序本身并入了专门的管理逻辑的应用程序。
3.想在自己的用户界面中集成 SQL Server 管理任务的应用程序。
SQLDMO对象来自SQLDMO.dll,SQLDMO.dll是随SQL Server2000一起发布的。SQLDMO.dll自身是一个COM对象,因此,在你的.NET项目里必须先引用它。
{
//引用SQLDMO.dll,SQLDMO由Microsoft SQL Server自带的SQLDMO.dll提供,SQLDMO.dll是一个COM对象
SQLDMO.Backup backup=new SQLDMO.BackupClass();
SQLDMO.SQLServer sqlserver=new SQLDMO.SQLServerClass();
sqlserver.LoginSecure=false;
sqlserver.Connect("localhost","sa","1");
backup.Action=SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
backup.Database="userdb";
backup.Files=@"E:/Project/meng/data/userdb.bak";
backup.BackupSetName="userdb";
backup.BackupSetDescription="数据库备份";
backup.Initialize=true;
backup.SQLBackup(sqlserver);
}
privatevoidButton4_Click(objectsender, System.EventArgs e)
{
SQLDMO.Restore restore=new SQLDMO.RestoreClass();
SQLDMO.SQLServer sqlserver=new SQLDMO.SQLServerClass();
sqlserver.LoginSecure=false;
sqlserver.Connect("192.168.19.25","sa","sa"); restore.Action=SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMORestore_Database;
restore.Database="userdb";
restore.Files=@"E:/Project/meng/data/userdb.bak";
restore.BackupSetName="userdb";
restore.FileNumber=1;
restore.SQLRestore(sqlserver);
}
//得到指定SQL服务器所有数据库的列表
publicArrayList GetDataBaseList(stringServerName,stringUserName,stringPwd)
{
ArrayList list = new ArrayList() ;
SQLDMO.Application sqlApp = new SQLDMO.Application() ;
SQLDMO.SQLServer oServer = new SQLDMO.SQLServer() ;
oServer.Connect(ServerName,UserName,Pwd);
foreach(SQLDMO.Database db in oServer.Databases)
{
if((db.Name!=null) && (db.SystemObject == false))
list.Add(db.Name);
}
return list ;
}
//得到SQL服务器的列表
publicArrayList GetSqlServerList()
{
ArrayList list = new ArrayList() ;
SQLDMO.Application sqlApp = new SQLDMO.Application();
SQLDMO.NameList ServerName = sqlApp.ListAvailableSQLServers();
for(int i=0;i<ServerName.Count;i++)
{
list.Add(ServerName.Item(i+1));
}
return list;
}
转载于:https://www.cnblogs.com/meimao5211/p/3339892.html
[整理] C#调用SQLDMO.DLL时间数据库备份 / 还原。 (香神无涯) // C#实现SQLSERVER2000数据库备份还原的两种方法 (带进度条)...相关推荐
- oracle如何对数据库进行备份,对Oracle数据库进行备份的两种方法详解
首页 > 演讲稿 > 自我介绍演讲稿 > 对Oracle数据库进行备份的两种方法详解 对Oracle数据库进行备份的两种方法详解 时间:2019-05-05 来源:自我介绍演讲稿 ...
- Database之SQLSever:SQLSever数据库管理(GUI法/SQL语句命令法两种方法实现备份(完整备份、差异备份、日志备份)、还原、删除、修改数据库等案例)之详细攻略
Database之SQLSever:SQLSever数据库管理(GUI法/SQL语句命令法两种方法实现备份(完整备份.差异备份.日志备份).还原.删除.修改数据库等案例)之详细攻略 目录 数据库管理 ...
- 服务器异地备份共享文件夹方法,mssql数据库异地备份的两种方法
mssql数据库异地备份的两种方法 /*两种方法的前提:1.本地服务器的sqlserver agent服务保证处于启动状态 2.远程计算机(计算机管理里)建立一个普通权限用户,并为其加上密码(例如用户 ...
- zpl java_JAVA调用DLL的两种方法-ZPL中文打印(作者不详,如有冒犯,请联系我)...
JAVA调用DLL的两种方法 (2008-03-05 17:24:48) 标签: 问题描述: 方法一,使用JNI: public class TestNative { private native s ...
- VB中FSO的调用的两种方法
方法一: Dim objFso Set objFso = CreateObject("Scripting.FileSystemObject") ...
- mysql数据库导入到excel表格数据_[转载]将EXCEL表格中的数据导入mysql数据库表中(两种方法)...
今天项目上遇到需要将excel中的数据导入到数据库的classify表中,于是乎拼命上网查阅方法,发现以下两种方法比较可行: 在此之前先说说按照网上的说法我没有试验成功的方法,将excel文件xls保 ...
- cpp 怎么连接mysql_C++连接mysql数据库的两种方法
现在正做一个接口,通过不同的连接字符串操作不同的数据库.要用到mysql数据库,以前没用过这个数据库,用access和sql server比较多.通过网上的一些资料和自己的摸索,大致清楚了C++连接m ...
- dapper mysql 批量_MySQL数据库之c#mysql批量更新的两种方法
本文主要向大家介绍了MySQL数据库之c#mysql批量更新的两种方法 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. 总体而言update 更新上传速度还是慢. 1: 简单的 ...
- 把EXCEL表格导入到MYSQL中_将EXCEL表格中的数据导入mysql数据库表中(两种方法)...
今天项目上遇到需要将excel中的数据导入到数据库的classify表中,于是乎拼命上网查阅方法,发现以下两种方法比较可行: 在此之前先说说按照网上的说法我没有试验成功的方法,将excel文件xls保 ...
最新文章
- 工业云计算在中国工业领域的发展与应用趋势
- 新手探索NLP(十一)——知识图谱
- python乘法口诀-怎么用Python把这样的乘法口诀表打出来?
- VTK:Utilities之PCAStatistics
- android触摸效果,Android UI实现单行文本水平触摸滑动效果
- c语言调用createthread线程的头文件_易语言API多线程总汇
- 全国计算机准考证打印2015年,甘肃2015下半年全国计算机等级考试准考证打印时间...
- [IE编程] IE的Killbit 技术详解
- 《请君入瓮——APT攻防指南之兵不厌诈》目录—导读
- 基于MFC的人事管理系统 VC++
- 小米微信双开开启谷歌服务器,小米10怎么双开微信 具体设置方法分享
- 双非本科地信前端面试题目
- mySQL中的内外连接
- 基于yolov5s+bifpn实践隧道裂缝裂痕检测
- 如何在模拟器里面脱360的壳
- rust建造一键升级_rust 使用国内镜像,快速安装方法
- 《The Ph.D. Grind》读后感
- iOS 设置代理详细步骤
- 计划赶不上变化,为什么还要计划呢?
- Unity用Mesh画多边形、圆形