/// <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数据库备份还原的两种方法 (带进度条)

 

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

 

SQLDMO类的使用

sql serversqlservermicrosoftdatabasestring数据库

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项目里必须先引用它。

sql server 差异还原 sql server怎么还原_SQL

sql server 差异还原 sql server怎么还原_SQL_02

private void Button3_Click(object sender, System.EventArgs e)
{
    //引用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.Actinotallow=SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
    backup.Database="userdb";
    backup.Files=@"E:/Project/meng/data/userdb.bak";
    backup.BackupSetName="userdb";
    backup.BackupSetDescriptinotallow="数据库备份";
    backup.Initialize=true;
    backup.SQLBackup(sqlserver);
}

private void Button4_Click(object sender, 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.Actinotallow=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服务器所有数据库的列表
        public ArrayList GetDataBaseList(string ServerName,string UserName,string Pwd)
        {
            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服务器的列表
        public ArrayList 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;
        }