如何在VB中备份及恢复SQL数据库,用SQL当后台数据库(请高手给出代码,谢谢!)

hongjiduan 2003-10-17 05:07:51
我是用VB连接SQL数据库的,现在想在VB下通过代码去实现对SQL数据库的备份,而备份可以备份到任何一个磁盘中去,然后又可以从盘中可以再恢复过来,请高手们给出代码,谢谢!
...全文
266 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
阿建像熊猫 2003-10-20
  • 打赏
  • 举报
回复
如何创建数据库备份 (Transact-SQL)
创建数据库备份

执行 BACKUP DATABASE 语句以创建数据库备份,同时指定:
要备份的数据库的名称。


数据库备份将写入的备份设备。
指定(可选):
INIT 子句,通过它可以重写备份媒体,并在备份媒体上将该备份作为第一个文件写入。如果没有现成的媒体头,备份过程将自动写入一个。


SKIP 和 INIT 子句,通过它们可以在备份媒体中仍然存在未失效的备份,或在媒体本身的名称与备份媒体中的名称不匹配时重写备份媒体。


FORMAT 子句,通过它可以在第一次使用媒体时对备份媒体进行完全初始化,并覆盖任何现有的媒体头。
如果已经指定了 FORMAT 子句,则不需要指定 INIT 子句。



重要 当使用 BACKUP 语句的 FORMAT 子句或 INIT 子句时,一定要十分小心,因为它们会破坏以前存储在备份媒体中的所有备份。


示例
下例将整个 MyNwind 数据库备份到磁带上:

USE MyNwind
GO
BACKUP DATABASE MyNwind
TO TAPE = '\\.\Tape0'
WITH FORMAT,
NAME = 'Full Backup of MyNwind'
GO






如何还原数据库备份 (Transact-SQL)
还原数据库备份



重要 还原数据库备份的系统管理员必须是唯一一位当前使用要还原的数据库的人。

执行 RESTORE DATABASE 语句以还原数据库备份,同时指定:
要还原的数据库名称。


要从其中还原数据库备份的备份设备。


NORECOVERY 子句,如果要在还原数据库备份后应用事务日志或差异数据库备份的话。
指定(可选):
FILE 子句,以此标识备份设备上要还原的备份集。
示例
下例从磁带还原 MyNwind 数据库备份:

USE master
GO
RESTORE DATABASE MyNwind
FROM TAPE = '\\.\Tape0'
GO


woshixirui 2003-10-20
  • 打赏
  • 举报
回复
yoki(小马哥):
在数据恢复的时候,显示数据库正在使用,我的其他代码通过ODBC连接,是不是与ODBC有关,请解决该问题。谢谢。
txlicenhe 2003-10-18
  • 打赏
  • 举报
回复
数据库备份/恢复方案
http://expert.csdn.net/Expert/topic/2359/2359124.xml?temp=.3535425
Jackile 2003-10-18
  • 打赏
  • 举报
回复
你真强,全被你说了!
bigpig 2003-10-18
  • 打赏
  • 举报
回复
up
yoki 2003-10-17
  • 打赏
  • 举报
回复
*********************************************************
'* 名称:BackupDatabase
'* 功能:备份数据库
'* 控件:一个文本框和两个按钮(备份到和确定)
'*********************************************************
Public Sub BackupDatabase()
Dim cn As New ADODB.Connection
Dim s_path, s_dataexport As String
s_path = App.Path
Me.MousePointer = 11 '设置鼠标指针形状
'student1是需要备份的数据库名称
s_dataexport = "backup database student1 to disk='" + CommonDialog1.FileName + "'"
cn.Open "driver={sql server};server=" & d1 & ";database=student1;persist security info=false; userid=sa" '数据库连接字符串
'这里不需要连接master数据库,即可完成备份
cn.BeginTrans
cn.Execute s_dataexport
Err.Number = 0
If Err.Number = 0 Then
cn.CommitTrans
MsgBox "数据备份成功!", vbInformation, "提示"
MsgBox "数据备份文件存放路径:" & CommonDialog1.FileName, vbOKOnly, "提示"
Unload Me
Else
cn.RollbackTrans
MsgBox "数据备份失败!请检查数据库是否正在打开!", vbCritical, "提示"
End If
cn.Close
Set cn = Nothing
Me.MousePointer = 1
End Sub



'*********************************************************
'* 名称:RestoreDataBase
'* 功能:还原数据库
'* 控件:一个文本框和两个按钮( 打开和确定)
'*********************************************************
Public Sub RestoreDataBase()
If Text1.Text = "" Then
MsgBox "请选择要恢复的数据文件!", vbInformation, "提示"
Exit Sub
Else
ret = MsgBox("数据恢复操作将会覆盖以前的所有数据并且覆盖后无法恢复,您确定要进行恢复操作吗?", vbQuestion + vbOKCancel, "提示")
If ret = vbOK Then
Dim cn As New ADODB.Connection
Dim sn As New ADODB.Recordset
Dim s_restore As String
Me.MousePointer = 11
cn.Open "Provider=SQLOLEDB.1;Persist Security Info=False;server=" & d1 & ";Initial Catalog=master;Data Source=127.0.0.1;user id=sa;password=" & d3 & ""
sn.Open "select spid from sysprocesses where dbid=db_id('student1')", cn
Do While Not sn.EOF
cn.Execute "kill " & sn("spid")
sn.MoveNext
Loop
sn.Close
s_restore = "restore database student1 from disk='" + Trim(Text1.Text) + "' with REPLACE"
cn.Execute s_restore
'Debug.Print gs_conn_string
'此时需要连接master数据库才能完成数据恢复操作
'同上student1为需要恢复的数据库
s_restore = "restore database student1 from disk='" + Trim(Text1.Text) + "'"
'text1一个用于记录需要恢复文件的地址的textbox
cn.Execute s_restore
cn.BeginTrans
If Err.Number = 0 Then
cn.CommitTrans
MsgBox "数据恢复成功!", vbInformation, "提示"
Command1.Enabled = True
Label1.Visible = False
Else
cn.RollbackTrans
MsgBox "数据恢复失败!", vbCritical, "提示"
Command1.Enabled = True
End If
cn.Close
Set cn = Nothing
Me.MousePointer = 1
Else
Exit Sub
End If '''''''''''''''''''''''''''''''''''''''''
On Error Resume Next
Dim DBC As New DataBaseConnection
If db.State = 1 Then
db.Close
End If
db.ConnectionString = DBC.SqlConnectString(d1, d2, d3)
rs.CursorType = adOpenDynamic
rs.CursorLocation = adUseClient
rs.LockType = adLockOptimistic
db.CursorLocation = adUseClient
db.Open
Set cmd.ActiveConnection = db
If Err.Number Then
MsgBox Err.Description, 16 + vbOKOnly, Err.Number
Exit Sub
End If
db.DefaultDatabase = "student1"
If Err.Number Then
MsgBox Err.Description, 16 + vbOKOnly, Err.Number
Exit Sub
End If
End If
End Sub '''''''''''''''''''''''''''''''''''''''''''''

如果当前没有与要恢复的数据库立连接,则不需要加单引号中的内容。

如果希望恢复数据库之后继续建立连接,则需要写这部分代码。

我要恢复数据库名称为student1,备份数据库的时候是在连接状态下进行的,但是恢复数据库不可以在数据库存在连接的状态下进行操作!代码的解决方法是:先连接SQL Server中主库master 库,在该库中的sysprocesses表中存放着所有连接到此数据库的连接信息,将这些连接信息用Kill语句删除。然后再恢复数据库student1,由于用Kill语句后,数据库已经被断开,所以在恢复完成后,再用系统最初的连接数据库代码连接上数据库student1。
yoki 2003-10-17
  • 打赏
  • 举报
回复
------------------------------------------------------------------
' 代码描述:SQL Server数据库的备份与恢复
'
' 注意事项:1.需要在工程中引用Microsoft SQLDMO Object Library
' 2.备份/恢复数据库时,要保证没有其它用户连接到SQL Server
'
' 窗体控件:2个Command,名称分别为cmdBackup,cmdRestore
' 1个Label,名称为lblProgress,用于显示备份/恢复进程。

'------------------------------------------------------------------
'
Option Explicit

Private WithEvents objBackup As SQLDMO.Backup
Private WithEvents objRestore As SQLDMO.Restore

Private Sub cmdBackup_Click()
Dim objSQLServer As New SQLDMO.SQLServer
Dim strServer As String
Dim strUserID As String
Dim strPassword As String
Dim strDatabase As String
Dim strFile As String

strServer = "Developer"
strUserID = "SA"
strPassword = ""
strDatabase = "Test"
strFile = "c:\test.bak"

If Dir(strFile) <> "" Then
If MsgBox("文件" & strFile & "已存在,是否删除?", vbQuestion + vbYesNo) = vbYes Then
Kill strFile
Else
Exit Sub
End If
End If

lblProgress.Caption = "备份进度: 0%"
Screen.MousePointer = 11

On Error GoTo ErrorHandler

objSQLServer.Connect strServer, strUserID, strPassword

Set objBackup = New SQLDMO.Backup
With objBackup
.PercentCompleteNotification = 1
.Database = strDatabase
.Files = strFile
.SQLBackup objSQLServer
End With
Set objBackup = Nothing

objSQLServer.Close
Set objSQLServer = Nothing

Screen.MousePointer = 0
Exit Sub

ErrorHandler:
Screen.MousePointer = 0
MsgBox Err.Description, vbCritical
End Sub

Private Sub cmdRestore_Click()
Dim objSQLServer As New SQLDMO.SQLServer
Dim strServer As String
Dim strUserID As String
Dim strPassword As String
Dim strDatabase As String
Dim strFile As String

strServer = "Developer"
strUserID = "SA"
strPassword = ""
strDatabase = "Test"
strFile = "c:\test.bak"

If Dir(strFile) = "" Then
MsgBox "文件" & strFile & "不存在!", vbExclamation
Exit Sub
End If

lblProgress.Caption = "恢复进度: 0%"
Screen.MousePointer = 11

On Error GoTo ErrorHandler

objSQLServer.Connect strServer, strUserID, strPassword

Set objRestore = New SQLDMO.Restore
With objRestore
.PercentCompleteNotification = 1
.Database = strDatabase
.ReplaceDatabase = True
.Files = strFile
.SQLRestore objSQLServer
End With
Set objRestore = Nothing

objSQLServer.Close
Set objSQLServer = Nothing

Screen.MousePointer = 0
Exit Sub

ErrorHandler:
Screen.MousePointer = 0
MsgBox Err.Description, vbCritical
End Sub

Private Sub objBackup_Complete(ByVal Message As String)
lblProgress.Caption = "备份成功!"
Set objBackup = Nothing
End Sub

Private Sub objBackup_PercentComplete(ByVal Message As String, ByVal Percent As Long)
lblProgress.Caption = "备份进度: " & Percent & "%"
DoEvents
End Sub

Private Sub objRestore_Complete(ByVal Message As String)
lblProgress.Caption = "恢复成功!"
Set objRestore = Nothing
End Sub

Private Sub objRestore_PercentComplete(ByVal Message As String, ByVal Percent As Long)
lblProgress.Caption = "恢复进度: " & Percent & "%"
DoEvents
End Sub

'备份数据库

'需要添加一个commoldialog控件
Sub backDataBase()
On Error GoTo errnum
dlg.CancelError = True
Cn1.Execute "use master"
dlg.Filter = "(*.bak)|*.bak"
dlg.ShowSave
MousePointer = 11
Cn1.Execute "BACKUP DATABASE kffgl TO DISK = '" & dlg.FileName & "'" '备份数据库
MousePointer = 0
Set Cn1 = Nothing
'重新建立连接
errnum:


Call dbint
Set Cn1 = New ADODB.Connection
Cn1.Open "Driver={SQL Server};Server=" & SQL_SRV & ";Uid=" & SA & ";Pwd=" & PA & ";Database=" & SJK & ""
End Sub



用SQLDMO实现备份




添加进度条ProgressBar1控件
引用Microsoft SQLDMO Object Library

'声明
Public WithEvents bkps As SQLDMO.Backup
'数据库备份操作
Private Sub Command3_Click()
Dim oSvr As SQLDMO.SQLServer
Set oSQLServer = CreateObject("SQLDMO.SQLServer")
oSQLServer.LoginSecure = False
oSQLServer.Connect ("(local)"), ("sa"), ("")'连接服务器
Screen.MousePointer = 11
Set bkps = CreateObject("SQLDMO.Backup")
bkps.Database = "db"'指定需备份的数据库
bkps.Action = 0
bkps.Files = "c:\backup\db.bak"'指定备份文件
bkps.Initialize = True
ProgressBar1.Value = 0
ProgressBar1.max = 100
Screen.MousePointer = 0
DoEvents
Err = 0
bkps.SQLBackup oSQLServer
Screen.MousePointer = 11
ProgressBar1.Value = 100
DoEvents
Set bkps = Nothing
Screen.MousePointer = 0
MsgBox "数据库备份完成"
End Sub
'显示进度
Private Sub bkps_PercentComplete(ByVal Message As String, ByVal Percent As Long)
ProgressBar1.Value = ProgressBar1.max * (Percent / 100)
End Sub

备份时ProgressBar1显示进度,恢复操作方法相同。
gs_luoqiang 2003-10-17
  • 打赏
  • 举报
回复
把服务停掉然后拷贝就可以了
数据库商品销售管理系统课程设计 课程设计名称: 数据库应用课程设计 专 业 班 级 : 计算机应用与技术 学 生 姓 名 : 学 号 : 指 导 教 师 : 课程设计时间:2011.12.20-2010.12.24 计算机应用技术专业课程设计任务书 学生姓名 专业班级 学号 题 目 商品销售管理系统 课题性质 A(工程设计 课题来源 D(自拟课题 指导教师 同组姓名 何亚伟 主要内容: 商品销售系统是用来帮助使用者管理商品销售流程的软件。使用者通过对 销售过程所涉及到的商品、订单、销售商等信息的录入,便可以提供给不同 的用户能够轻松实现商品销售流程的管理。 系统开发的目的是在节省人力的基础上更加快捷方便的为顾客服务并为公主要内容 司盈利。 前台开发工具用的是vb后台数据库采用的SQL SERVER. 任务要求 在所设计的软件必须向使用者提供商品基本的录入、删除、编辑等功能。 能对各种商品的基础信息进行维护和管理。能够完成商品信息的添加)修改和 删除,也可以按照一定的条件查询商品信息。 [1] 龚沛曾、杨志强、袁科萍 数据库技术与应用【M】 北京: 高等教育出版社,2008 [2] 宣小平.ASP.NET数据库系统开发实例导航.上海:人民邮电出版 社,2003.P.121-130. [3] 金银秋.数据库原理与设计.北京:科学出版社,2003.P.201-230. 参考文献 [4] 张海藩. 软件工程.北京:人民邮电出版社,2002.P.75-80. [5] 沃尔森. ASP.NET2.0揭秘(卷1). 谭振林.北京:人民邮电出版社. 2007-10-1.P.132-138. [6] 朱晔. ASP.NET 第一步——基于C#和ASP.NET2.0.北京:清华大学 出版社,.2007-7-1.P.301-310. 指导教师签字: 审查意见 教研室主任签字: 2010年 12月 20 日 一、 需求分析 1 系统需求分析 销售管理是企业管理的一个重要管理环节,它的特点是信息量大,要求信息反馈迅速 ,对企业经济效益能够产生直接的影响。同时,它与他的其他管理环节如库存管理)销售 账务管理等关系十分密切。采用传统的手工管理模式,其工作效率)管理质量和管理水平 已不能满足当今经营管理发展的要求,也无法和国外的企业进行竞争。只有采用先进的 计算机管理技术,把一些科学管理的技术及管理方式融入到企业销售管理,才能提高 工作效率和企业的管理水平,使企业能够随着市场的动态变化而随时调整自身的销售业 务流程,在瞬息万变的市场竞争脱颖而出。 商品销售系统是用来帮助使用者管理商品销售流程的软件。使用者通过对销售过程 所涉及到的商品、订单、销售商等信息的录入,便可以提供给不同的用户能够轻松实现 商品销售流程的管理。 因此该系统必须向使用者提供一下如下的一些具体功能: 1、在所设计的软件必须向使用者提供商品基本的录入、删除、编辑等功能。 2、由于商品具有不同的销售方式(可分为订单销售和代理商销售这两种形式),所以软 件必须得向使用者提供商品销售这个环节的基本管理功能,所以必须要有订单分销模 块和代理商分销模块。 3、软件必须得向使用者提供最基本的查询功能。 4、由于是销售管理软件,所以系统安全性必须是考虑的问题。因此,必须实现以下两 点:(1)系统操作员机制。对系统的使用者,按等级开房管理权限,这样可以在一定程度 上保证数据库系统的安全性,避免数据被泄漏,非法更改等。(2)销售数据直接反映了一 个销售单位的盈亏状况,鉴于销售的数据的重要性,所以必须对这些数据加以保护,在 系统崩溃时或者误操作等情况下,可以对数据进行恢复。这需要系统提供备份功能。 5、对于销售数据不能只存储在计算机,而是需要到处步骤,最后以印刷品的形式出 现在使用者面前,该软件设计的最终目的才能以具体的实现。所以,打印功能是必不可 少的系统功能之一。 2 数据库需求分析 数据库在一个信息管理系统占有非常重要的地位,数据库结构设计的好坏将直接对 应用系统的效率以及实现的效果产生影响。合理的数据库结构设计可以提高数据存储的 效率,保证数据的完整和一致。 数据库技术是由传统的文件系统发展而来的,从层次模型、网状模型发展到关系模型 。数据库技术是数据管理的最新技术,是计算机科学的一个重要分支,它能指导我们正 确地设计数据库系统,它的出现极大地促进了计算机应用的发展。采用数据库技术的原 理和方法可以有效地设计实用的数据库系统。一个完整的数据库系统包括数据库管理系 统(DBMS),数据库管理员(DBA)、数据库(DB)、应用程序和相应的硬件设施。 目前许多数据库管理系统都基于关系模型,关系模型的主要特点是用表格结构表达实 体,用键表示实体与实体之间的联系。与层次模型和网状模型相比,关系

1,216

社区成员

发帖
与我相关
我的任务
社区描述
VB 数据库(包含打印,安装,报表)
社区管理员
  • 数据库(包含打印,安装,报表)社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧