-2
第1步:我的备份使用此代码段(它工作正常)数据库保持为空
Public Shared Sub BackupDatabase()
Dim sConnect As String = My.Settings.LICConnectionString
Dim dbName As String
Using cnn As New SqlConnection(sConnect)
cnn.Open()
dbName = cnn.Database.ToString()
Dim sc As New ServerConnection(cnn)
Dim sv As New Server(sc)
' Check that I'm connected to the user instance
Console.WriteLine(sv.InstanceName.ToString())
' Create backup device item for the backup
Dim bdi As New BackupDeviceItem("C:\Backup\LIC.bak", DeviceType.File)
' Create the backup informaton
Dim bk As New Backup()
bk.Devices.Add(bdi)
bk.Action = BackupActionType.Database
bk.BackupSetDescription = "SQL Express is a great product!"
bk.BackupSetName = "SampleBackupSet"
bk.Database = dbName
bk.ExpirationDate = New Date(2007, 5, 1)
bk.LogTruncation = BackupTruncateLogType.Truncate
' Run the backup
bk.SqlBackup(sv)
MsgBox("Your backup is complete.")
End Using
End Sub
步骤2中的数据库:我删除表(所以数据库是空的)的所有数据。
第3步:使用此代码段从备份中还原文件的数据库(它不抛出任何错误,并执行罚款)
Private Sub Restore(ByVal ConnectionString As String, ByVal DatabaseFullPath As String, ByVal backUpPath As String)
Using con As New SqlConnection(ConnectionString)
con.Open()
Dim UseMaster As String = "USE master"
Dim UseMasterCommand As New SqlCommand(UseMaster, con)
UseMasterCommand.ExecuteNonQuery()
Dim Alter1 As String = "ALTER DATABASE [" & DatabaseFullPath & "] SET Single_User WITH Rollback Immediate"
Dim Alter1Cmd As New SqlCommand(Alter1, con)
Alter1Cmd.ExecuteNonQuery()
Dim Restore As String = "RESTORE DATABASE [" & DatabaseFullPath & "] FROM DISK = N'" & backUpPath & "' WITH FILE = 1, NOUNLOAD, STATS = 10"
Dim RestoreCmd As New SqlCommand(Restore, con)
RestoreCmd.ExecuteNonQuery()
Dim Alter2 As String = "ALTER DATABASE [" & DatabaseFullPath & "] SET Multi_User"
Dim Alter2Cmd As New SqlCommand(Alter2, con)
Alter2Cmd.ExecuteNonQuery()
MsgBox("Successful")
End Using
End Sub
不过,这并不表中显示的数据。我意思后,我恢复的数据库中,我应该从备份文件中的旧数据...但数据库表保持为空..
u能指导我这个?
你的假设是不正确的;你说这两个备份和恢复“工作正常”,但这显然*不真实*。 – 2012-01-15 09:19:28
它不会抛出任何错误...任何想法我哪里错了? – 2012-01-15 09:23:40
不知道*在所有*,因为你从来没有测试过,如果备份*真的工作* ... – 2012-01-15 09:26:25