转载:http://www.cnblogs.com/liulanglang/archive/2007/12/04/981812.html

上周要写一个SQL-SERVER数据库备份还原的程序,很没有思路,只是记得上学的时候用过SQL语句来完成数据库的备份还原,其余的方式还没有尝试过。经过资料查找终于找到了解决方案,效果还不错,于是写下来一起分享。

大家最常见的是使用sql命令来进行数据库备份,

最常用的sql语句如下:

backup [dbname]   to   disk=[路径+文件名]

restore [dbname]   from   disk=[路径+文件名]

另外可以使用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 企业管理器执行的所有功能。

在ASP.NET2005中要使用SQLDMO.DLL,首先要注册这个组件。注册SQLDMO.DLL组件的步骤:

1.“项目”——>“添加引用”——>“COM”——>“SQLDMO.DLL”这样就可以注册SQLDMO.DLL组件。

2.把在C:\Program Files\Microsoft SQL Server\80\Tools\Binn目录下的动态链接库SQLDMO.DLL文件。

3. 把DLL文件持拷贝到C:\WINDOWS\system32目录下

4. 在C:\WINDOWS\system32目录下建立一个新文件夹:resources,在里面再建一个新文件夹2052,然后把RLL文件拷贝到2052中.即放在C:\WINDOWS\system32\resources\2052目录中

5.注册:在开始>>运行>>(输入)Regsvr32 C:\Program Files\Microsoft SQL Server\80\Tools\Binn\sqldmo.dll 回车。

注册过SQLDMO.DLL组件后,在C#中使用这个组件来进行开发的方式有点不同。

在C#的Web程序中使用这个组件,要在“解决资源管理器”中添加上SQLDMO.DLL组件的引用。然后在项目的命名空间中添加“using SQLDMO;”命名空间的引用,完成以上操作就可以在Web项目中使用这个组件了。

具体步骤:选中“解决资源管理器”的项目,右键,“添加引用”,然后在COM选项中选择SQLDMO.DLL组件进行添加。

在Windows项目中就不需要这么麻烦,只要完成SQLDMO.DLL组件的步骤的注册步骤,直接在Windows程序中可以添加此引用“using SQLDMO;”,就可以直接使用这个组件。

下面是用C#语言写的备份和恢复Microsoft SQL Server数据库的实现方式:

(提醒:首先要注册SQLDMO.DLL组件在WEB程序中使用SQLDMO.DLL组件,要添加SQLDMO.DLL的引用;在Windows项目中使用SQLDMO.DLL组件,注册后直接添加using SQLDMO;)

///<summary>

/// 数据库备份

/// 参数信息要备份的数据库的名称Backup .Database = "Northwind";

/// 另外一个是存放备份文件的路径和文件名称Backup .Files = @"c:\databak.bak";

///</summary>

private   void   Button1_Click(object   sender,   System.EventArgs   e)

{

SQLDMO.Backup Backup = new SQLDMO.BackupClass();

SQLDMO.SQLServer SQLServer = new SQLDMO.SQLServerClass();

try

{

SQLServer.LoginSecure = false;

SQLServer.Connect("IP", "USERNAME", "PWD");

Backup .Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMBackup _Database;

Backup .Database = "Northwind";//要备份的数据库的名称,例如Northwind

Backup .Files = @"c:\databak.bak";//存放路径,和备份文件的名称

Backup .BackupSetName = "Northwind";

Backup .BackupSetDescription = "数据库备份";

Backup .Initialize = true;

Backup .SQLBackup(SQLServer);

}

Catch(Exception ex)

{

Throw ex;

}

finally

{

SQLServer.DisConnect();

}

}

///<summary>

/// 数据库恢复

/// 参数信息要恢复的数据库的名称Restore .Database = "Northwind_Res";

/// 另外一个是存放数据库备份文件的路径和文件名称

/// Backup .Files = @"c:\databak.bak";用来恢复数据库

///</summary>

private   void   Button2_Click(object   sender,   System.EventArgs   e)

{

SQLDMO.Restore Restore = new SQLDMO.RestoreClass();

SQLDMO.SQLServer SQLServer = new SQLDMO.SQLServerClass();

try

{

SQLServer.LoginSecure = false;

SQLServer.Connect("IP", "USERNAME", "PWD");

Restore .Action = SQLDMO.SQLDMO_RESTORE_TYPE.SQLDMRestore _Database;

Restore .Database = "Northwind_Res";

Restore .Files = @"C:\ databak.bak";

Restore .FileNumber = 1;

Restore .ReplaceDatabase = true;

Restore .SQLRestore(SQLServer);

}

catch(Exception ex)

{

Throw ex;

}

finally

{

SQLServer.DisConnect();

}

}

}

其实这种方式是调用SQL-SERVER数据库自带的数据备份功能,这个功能是使用上面说过是两个sql语句,只不过是形成了存储过程的形式。在SQL-SERVER系统中有这两个SQL命令生成的存储过程,如下。

backup [dbname]   to   disk=[路径+文件名]

restore [dbname]   from   disk=[路径+文件名]
其实还有另外一种方式实现的数据库备份还原的方法,经过尝试我使用的是第二种方法。 这种方法是使用自定义的存储过程来实现的,声明下面这篇文章中的存储过程是转载的,但是方法很不错! http://www.cnblogs.com/liulanglang/archive/2007/12/04/981821.html

动态备份SQL-SERVER数据库——SQLDMO的更多相关文章

  1. 定时备份SQL Server数据库

    一.手动备份: 1.整个数据库备份:选择数据库 => 右键任务 => 备份: 2.导出一张表的框架:选择表 => 编写表脚本为 => CREATE到: 3.导出一张表的数据:  ...

  2. 如何远程备份sql server数据库

      方法一(不使用SQLDMO): /// ///备份方法 /// SqlConnection conn = new SqlConnection("Server=.;Database=mas ...

  3. 如何使用代码备份SQL Server数据库

    1.添加引用 using Microsoft.SqlServer.Management.Smo; using Microsoft.SqlServer.Management.Common; 2. Bac ...

  4. SQL Server 数据库定时自动备份

    原文:SQL Server 数据库定时自动备份 SQL Server 数据库定时自动备份——每天定时备份,保留前8天的备份 利用SQL Server代理新建作业来定期备份 1)在数据库库的[SQL S ...

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

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

  6. 在.Net中进行SQL Server数据库备份与还原操作实用类

    #region 类说明 //----------------------------------------------------------------------------- // // 项目 ...

  7. SQL Server数据库定时自动备份

    SQL Server 数据库定时自动备份[转]   在SQL Server中出于数据安全的考虑,所以需要定期的备份数据库.而备份数据库一般又是在凌晨时间基本没有数据库操作的时候进行,所以我们不可能要求 ...

  8. SQL Server数据库备份的镜像

    SQL Server数据库备份的镜像 一个完整备份可以分开镜像 USE master GO BACKUP DATABASE [testdatabase] TO DISK = N'C:\testdata ...

  9. Sql Server数据库备份和恢复:原理篇

    本文与您探讨为什么Sql Server有完整备份.差异备份和事务日志备份三种备份方式,以及为什么数据库又有简单模式.完整模式和大容量日志模式这三种恢复模式.本文内容适用于2005以上所有版本的Sql ...

  10. SQL SERVER 数据库备份的三种策略及语句

    1.全量数据备份    备份整个数据库,恢复时恢复所有.优点是简单,缺点是数据量太大,非常耗时 全数据库备份因为容易实施,被许多系统优先采用.在一天或一周中预定的时间进行全数据库备份使你不用动什么脑筋 ...

随机推荐

  1. Codeforces Beta Round #16 E. Fish (状压dp)(概率dp)

    Codeforces Beta Round #16 (Div. 2 Only) E. Fish 题目链接:## 点击打开链接 题意: 有 \(n\) 条鱼,每两条鱼相遇都会有其中一只吃掉对方,现在给你 ...

  2. 去哪网实习总结:用到的easyui组件总结(JavaWeb)

    本来是以做数据挖掘的目的进去哪网的,结构却成了系统开发... 只是还是比較认真的做了三个月,老师非常认同我的工作态度和成果.. . 实习立即就要结束了,总结一下几点之前没有注意过的变成习惯和问题,分享 ...

  3. Maven报错Missing artifact jdk.tools:jdk.tools:jar:1.7--转

    原文地址:http://blog.csdn.net/u013281331/article/details/40824707 在Eclipse中检出Maven工程,一直报这个错:“Missing art ...

  4. IE9下不显示select

    由于IE8和IE9下不兼容,需要在头部加入: <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7&q ...

  5. [Node.js] Testing ES6 Promises in Node.js using Mocha and Chai

    Writing great ES6 style Promises for Node.js is only half the battle. Your great modules must includ ...

  6. centos 查询DNS

    cat  /etc/resolv.conf

  7. ModSecurity防御暴力破解

    http://www.modsecurity.org/ ModSecurity防御暴力破解 在阅读本文前,先简单了解下什么是ModSecurity,ModSecurity是一个入侵探测与阻止的引擎.它 ...

  8. Kinect for Xbox one(v2) + Ubuntu 14.04 +ROS 安装

    相比于kinect for xbox 360(v1)通过结构光来获取深度,Kinect for Xbox one(v2) 采用time flight技术,极大改善了深度图像的性能. kinect fo ...

  9. angular的Dom操作

    原文 https://www.jianshu.com/p/9d7249922bda 大纲 1.angular的DOM操作 2.为什么不能直接操作DOM? 3.三种错误操作DOM的方式 4.angula ...

  10. Spring boot(三) springboot 定时任务

    这个不多说,springboot 定时任务非常简单就可以实现了. 30s运行一次 , @Scheduled(cron="0,30 * * * * ?") 通过这个控制定时时间 cr ...