用VB备份和恢复SQL Server数据库的方法

server|备份|恢复|数据|数据库

摘要 备份与恢复是数据库管理员维护数据库安全性和完整性的重要操作。本文分析并介绍用Access备份SQL数据库的方法,很好地达到了数据备份的目的。同时,就Access 数据库的安全接口作了简略讨论,使备份后不致丧失数据安全性。并提出了改进备份与恢复策略的一些建议。

  引言

  对于关键应用的数据库系统应根据具体环境和条件制订一个完善可行确保系统安全的备份计划,没有备份的系统是不可靠、危险的,后果将是严重的,破坏性病毒、误操作、自然灾害等等都可能会对数据库系统造成难以估量的破坏。尤其对一个信息化程度较高的企业来说,最有价值的财产或许就是企业数据库中的数据。一个系统中最重要的是大量的实时数据,没有备份功能显然是不安全和不完善的。经过实践摸索出Visual Basic 6.0开发的备份程序,能将数据库备份到Access数据库(Access 为目前流行的桌面型数据库产品, 具有存储操作灵活、便利等优点, 并且因它与SQL Server 同属微软数据库产品, 二者能很好地兼容)中,并对Access数据库进行加密以防数据被非法访问。该程序还能用Access备份库的数据恢复SQL Server数据库,从而减少因误操作损坏数据内容而造成的损失。使用该方法,用户不须添加额外设备,只须在原有服务器上运行该备份程序,其界面简单方便,适合普通用户使用。

  备份与恢复概述

  备份是数据库管理员定期地将整个数据库复制到磁带或另一个磁盘上保存起来的过程。常用的数据备份类型有:完全备份、差异备份、事务日志备份、文件或文件组备份。一个通用的备份策略是:以较长的时间间隔执行完全备份,以适中的时间间隔进行差异备份,并以较短的时间间隔进行事务日志备份。当数据遭到破坏后就可以利用备份来恢复数据库。恢复数据库是一个装载数据库的备份,然后应用事务日志重建的过程。一个通用的恢复策略是:首先恢复完全备份的数据,然后恢复差异备份数据,最后根据事务日志备份进行恢复。

  1、备份方案

  开发所需软件:Visual Basic 6.0 Access备份程序的设计方法:

  (1) 用控制面版的ODBC设置,给SQL Server中的数据库添加一个数据源名称。

  (2) 在Access中新建一个数据库,命名为backup.mdb。

  (3) 用VB定义两个主要过程:Attach_Table()和Create_Table()。Attach_Table的作用是将SQL Server数据库中的所有需要备份的表链接到Access数据库中,在此过程中要排除系统表,因为那是SQL Server自创建的,表中无用户数据。Create_Table的作用是在backup.mdb中创建目的表,即在这个备份Access库中创建表用来保存所有存在SQL数据库中的用户数据。另外,在链接过程中,要去掉SQL Server自带的拥有者名称。

  2、程序的逻辑结构

  ① 通过第一步创建的ODBC数据源打开要备份的SQL数据库;

  ② 使用Attach_Table()将该数据库中的所有用户表链接到backup.mdb中,排除系统表的方法是:
For Each tdf in backup_db.TableDefs
 If (tdf.attributes And dbSystemObject)=0 Then
  //条件成立,说明该表是用户定义的表,可以链接,否则跳过
 End if
Next

  ③ 使用Create_Table()对每个表创建与之对应的备份表,取名可遵循如下原则, 若原表叫table_name, 则备份表叫b_table_name。

  ④ 将table_name表中的所有记录复制到b_table_name中。

  ⑤从备份库删除对SQL数据表的链接。

  3、程序原码

  采用微软DAO (Data Access Object) 数据模型, 打开Access 本地数据库, 并连接一个外部ODBC数据表, 拷贝该表结构完成, 有以下过程块CopyStru :

Private Sub copyStru ()
 Set dbsTemp = wrkjet. OpenDatabase (tagFilName)// 链接表的过程
 For i = 0 To tabN - 1
  Set tdfLinked = dbsTemp. CreateTableDef (“linkTab”)
  tdfLinked. Connect = “OdbC; DATABASE = xgsbgsys ; UID =

  sa ; PWD = ; DSN = xgsdb ;”
  tdfLinked. SourceTableName = tabName (i)
  dbsTemp. TableDefs. Append tdfLinked
  Set temp Tab = dbsTemp. CreateTableDef ()
  temp Tab. Name = tabName (i)
  //创建新表的过程
  For Each fld In tdfLinked. Fields
   Set newFil = temp Tab. CreateField (fld. Name , fld. Type ,fld. Size)
   newFil. OrdinalPosition = fld. OrdinalPosition
   newFil. Required = fld. Required
   temp Tab. Fields. Append newFil
  Next
  //创建索引
  For Each idx In tdfLinked. Indexes
   Set newIdx = temp Tab. CreateIndex ()
   With newIdx
    Name = tabName (i) & ” x”
    Fields = idx. Fields
    Unique = idx. Unique
    Primary = idx. Primary
   End With
   temp Tab. Indexes. Append newIdx
  Next
  dbsTemp. TableDefs. Append temp Tab
  Set temp Tab = Nothing
  dbsTemp. TableDefs. Delete ”linkTab”
 Next i
 dbsTemp. Close
 Set dbsTemp = Nothing
 wrkjet. Close
 Set wrkjet = Nothing
End Sub
End Sub

[1] [2] 下一页  

时间: 2024-12-30 06:04:28

用VB备份和恢复SQL Server数据库的方法的相关文章

在C#中运用SQLDMO备份和恢复SQL Server数据库

server|备份|恢复|数据|数据库     SQLDMO(SQL Distributed Management Objects,SQL分布式管理对象)封装了Microsoft SQL Server数据库中的对象.SQLDMO是Microsoft SQL Server中企业管理器所使用的应用程序接口,所以它可以执行很多功能,其中当然也包括对数据库的备份和恢复. SQLDMO由Microsoft SQL Server自带的SQLDMO.dll提供,由于SQLDMO.dll是一个COM对象(有关C

用SQL备份和恢复SQL SERVER数据库

server|备份|恢复|数据|数据库 <HTML><HEAD><TITLE>SQL Server 数据库的备份与恢复</TITLE><meta http-equiv="Content-Type" content="text/html; charset=gb2312"></HEAD><BODY><form method="post" name=myform&

ASP.NET备份恢复Sql Server数据库

本文将向大家介绍如何使用 ASP.NET 备份恢复 Sql Server 数据库,大家可以做个参考,也希望对大家有所帮助. 备份SqlServer数据库: string SqlStr1 = "Server=(local);database='" + this.DropDownList1.SelectedValue + "';Uid=sa;Pwd=";string SqlStr2 = "backup database " + this.DropDo

如何通过备份文件恢复SQL Server数据库

阿里云关系型数据库(Relational Database Service,简称 RDS)是一种稳定可靠.可弹性伸缩的在线数据库服务.基于飞天分布式系统和高性能存储,RDS 支持 MySQL.SQL Server.PostgreSQL 和 PPAS( Postgre Plus Advanced server,一种高度兼容 Oracle 的数据库)引擎,并且提供了容灾.备份.恢复.监控.迁移等方面的全套解决方案,彻底解决数据库运维的烦恼. 应用场景 假如您用了阿里云的SQL Server RDS,

企业管理器备份和还原SQL Server数据库

在日常的数据库操作中,我们常常对数据库进行备份操作,以方便在数据库发生灾难时对数据库进行还原,从而确保数据库的安全性.SQL Server数据库使用企业管理器可以简单直观地完成这些操作,还可以每天自动备份数据库.本文我们就介绍了这一过程,接下来就让我们来一起了解一下吧. 一.备份数据库 1.打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server. 2.SQL Server组-->双击打开你的服务器-->双击打开数据库目录. 3.选择你的数据库名称(如论坛数据库F

企业管理器备份和还原SQL Server数据库_MsSql

在日常的数据库操作中,我们常常对数据库进行备份操作,以方便在数据库发生灾难时对数据库进行还原,从而确保数据库的安全性.SQL Server数据库使用企业管理器可以简单直观地完成这些操作,还可以每天自动备份数据库.本文我们就介绍了这一过程,接下来就让我们来一起了解一下吧. 一.备份数据库 1.打开SQL企业管理器,在控制台根目录中依次点开Microsoft SQL Server. 2.SQL Server组-->双击打开你的服务器-->双击打开数据库目录. 3.选择你的数据库名称(如论坛数据库F

go语言通过odbc访问Sql Server数据库的方法_Golang

本文实例讲述了go语言通过odbc访问Sql Server数据库的方法.分享给大家供大家参考.具体如下: 这里需要用到go-odbc库,开源地址为:https://github.com/weigj/go-odbc 复制代码 代码如下: package main; import (     "fmt"     "database/sql"     _"odbc/driver" ) func main(){     conn,err := sql.O

从日志中恢复SQL Server数据库到时间点

server|恢复|数据|数据库 Author:David EulerDate: 2004/10/16Email:de_euler-david@yahoo.com.cn 有任何问题,请与我联系:)          DB2中可以使得数据库回复到指定的时间点,SQL Server数据库的Recovery Model为full 或者Bulk copy的时候,是可以从日志来恢复数据库的.实际上日志中记录的一条一条的transact sql语句,恢复数据库的时候会redo这些sql语句.  前提条件:m

用ASP.NET还原与恢复SQL Server数据库

asp.net|server|恢复|数据|数据库 需要注意的是还原,还原的时候问题最大了,有别的用户使用数据库的时候无法还原,解决办法就是在MASTER数据库中添加一个存储过程: create proc killspid (@dbname varchar(20))asbegindeclare @sql nvarchar(500)declare @spid intset @sql='declare getspid cursor forselect spid from sysprocesses wh