ASP.NET下对远程SQL SERVER数据库的备份和恢复的存储过程

转载 2005年01月03日 09:54:00

Sql server的帮助文档地址,在IE里面直接输入就行
mk:@MSITStore:C:/Program%20Files/Microsoft%20SQL%20Server/80/Tools/Books/tsqlref.chm::/ts_ba-bz_35ww.htm

backup database to disk path备份
restore database from disk path恢复


using System;
using System.Collections;
using System.Security.Cryptography;

using System.Data;
using System.Data.SqlClient;
using System.Web;

using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

using System.Diagnostics ;
using System.Text ;
using System.ComponentModel;
using System.Configuration;
using System.Data.OleDb;

namespace DbService
{
 /// <summary>
 /// DbOper类,主要实现对Microsoft SQL Server数据库的备份和恢复
 /// </summary>
 public sealed class DbOper
 {
  /// <summary>
  /// DbOper类的构造函数
  /// </summary>
  //private DbOper()
  //{
  //}

  /// <summary>
  /// 数据库备份
  /// </summary>
  ///
  public static string BackFileName=System.Web.HttpContext.Current.Request.PhysicalApplicationPath+"BackUp//MyDbBack.bak";
  public static void DbBackup(string DbNanme,string userid,string pwd)
  {
   try
   {
    SQLDMO.Backup oBackup = new SQLDMO.BackupClass();
    SQLDMO.SQLServer oSQLServer = new SQLDMO.SQLServerClass();
    oSQLServer.LoginSecure = false;
    oSQLServer.Connect("localhost",userid,pwd);
    oBackup.Action = SQLDMO.SQLDMO_BACKUP_TYPE.SQLDMOBackup_Database;
    oBackup.Database = DbNanme;
    oBackup.Files =BackFileName;
    oBackup.BackupSetName =DbNanme;
    oBackup.BackupSetDescription = "数据库备份";
    oBackup.Initialize = true;
    oBackup.SQLBackup(oSQLServer);
   }
   catch
   {
    throw;
   }
  }

  

  /// <summary>
  /// 还原数据库函数
  /// </summary>
  /// <param name="strDbName">数据库名</param>
  /// <param name="strFileName">数据库备份文件的完整路径名</param>
  /// <returns></returns>
  public bool RestoreDB(string strDbName,string strFileName,string userid,string pwd)
  {
   //PBar = pgbMain ;
   SQLDMO.SQLServer svr = new SQLDMO.SQLServerClass() ;
   try
   {
    //服务器名,数据库用户名,数据库用户名密码
    svr.Connect("localhost",userid,pwd) ;
    
    SQLDMO.QueryResults qr = svr.EnumProcesses(-1) ;
    int iColPIDNum = -1 ;
    int iColDbName = -1 ;
    for(int i=1;i<=qr.Columns;i++)
    {
     string strName = qr.get_ColumnName(i) ;
     if (strName.ToUpper().Trim() == "SPID")
     {
      iColPIDNum = i ;
     }
     else if (strName.ToUpper().Trim() == "DBNAME")
     {
      iColDbName = i ;
     }
     if (iColPIDNum != -1 && iColDbName != -1)
      break ;
    }
    //杀死使用strDbName数据库的进程
    for(int i=1;i<=qr.Rows;i++)
    {
     int lPID = qr.GetColumnLong(i,iColPIDNum) ;
     string strDBName = qr.GetColumnString(i,iColDbName) ;
     if (strDBName.ToUpper() == strDbName.ToUpper())
     {
      svr.KillProcess(lPID) ;
     }
    }
               
    SQLDMO.Restore res = new SQLDMO.RestoreClass() ;
    res.Action = 0 ;
    res.Files = strFileName ;

    res.Database = strDbName ;
    res.ReplaceDatabase = true ;
    res.SQLRestore(svr) ;
    return true ;
   }
   catch
   {
    return false;
   }
   finally
   {
    svr.DisConnect() ;
   }
  }

 }
}

SQLSERVER远程备份、恢复

SQLSERVER服务实例名称:192.168.0.2需要备份的数据库名称: a备份机器名称(Client端):192.168.0.3备份机用户:zf 密码:123备份机域名:domain备份机提供备...
  • ahuu
  • ahuu
  • 2006年05月17日 16:20
  • 5101

存储过程备份和还原sqlserver

数据库列表:帐套数据库与系统数据库列表。 备份文件列表:数据源来自master.dbo.sys_BackupHistory表。 首先在master数据库建立3个存储过程及一个备份历史表...
  • sgpian
  • sgpian
  • 2016年08月02日 18:55
  • 1967

关于SQLServer数据库远程备份和还原的那些事儿

PS:本人本是一名机械男,11年毕业,四年前认识了我现在老婆,老婆是个.NET程序员,收她影响结合自身的兴趣爱好,两年前开始自学.NET,一年半前放弃某国企项目经理职位,转入IT行业。与公司众多的帅锅...
  • Arnold1988
  • Arnold1988
  • 2015年12月25日 16:14
  • 2134

SQL SERVER 2008 R2 远程备份数据库

题记因为之前出现服务器硬盘挂掉,数据库数据差点就木有了,这个问题很严重,因此就想这在局域网中其他机器也备份一下数据库。 使用方法: (1) 使用python,ssh2连接(通过密钥或账号/密码登陆);...
  • cdd801
  • cdd801
  • 2015年07月30日 10:25
  • 1836

MySQL和PostgreSQL的远程备份与恢复

远程备份: # mysqldump -h 192.168.0.2 -u root -p push --set-gtid-purged=OFF > backupfile.sql 远程恢复:# mys...
  • gaojinshan
  • gaojinshan
  • 2014年07月31日 16:17
  • 2471

sql server 脚本创建备份数据库的存储过程及利用前述存储过程自动备份数据库的作业

一、创建备份数据库的存储过程 /****** Object: Procedure [dbo].[SP_BackUp_DataBase_Log] Script Date: 3/10/2017 2:...
  • hejisan
  • hejisan
  • 2017年03月10日 15:09
  • 534

用SQL语言,实现数据库的备份/恢复的功能

体现了SQL Server中的四个知识点: 1.   获取SQL Server服务器上的默认目录 2.   ...
  • feng19821209
  • feng19821209
  • 2006年03月24日 09:32
  • 2350

PL/SQL远程备份和恢复Oracle数据库

首先无论你的Oracle服务器是Linux还是windows操作系统,Oracle的备份和恢复操作都是使用DBMS_DUMP来实现导入(备份)和导出(恢复)。首先你要安装好PL/SQL,用PL/SQL...
  • huchunfu
  • huchunfu
  • 2014年05月06日 23:56
  • 6680

ASP.NET中备份sqlserver数据库的方法

前言:我们在开发网站时,在管理后台,管理员通常要定期对数据库进行备份(当然也可以让sqlserver服务器定期自动备份,但我此处讲的是asp.net中的备份),备份的代码很简单:下面是我做一个网站后台...
  • j_jake
  • j_jake
  • 2007年08月03日 16:39
  • 1330

备份SQL SERVER远程数据库到本地

公司找了个坑爹的外包公司做了个官网。
  • Witch_Soya
  • Witch_Soya
  • 2014年09月28日 18:09
  • 13470
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET下对远程SQL SERVER数据库的备份和恢复的存储过程
举报原因:
原因补充:

(最多只允许输入30个字)