Save- und Open-Methoden (Beispiel) (VB)
Gilt für: Access 2013, Office 2013
In diesen drei Beispielen wird veranschaulicht, wie die Methoden Save und Open gemeinsam verwendet werden können.
Angenommen, Sie gehen auf eine Geschäftsreise und möchten eine Tabelle aus einer Datenbank mitnehmen. Bevor Sie fahren, greifen Sie auf die als ein Recordset-Objekt gespeicherten Daten zu und speichern Sie in einer transportierbaren Form. Wenn Sie an Ihrem Reiseziel ankommen, greifen Sie auf das Recordset -Objekt als ein lokales, getrenntes Recordset -Objekt zu. Sie nehmen Änderungen am Recordset -Objekt vor und speichern es erneut. Wenn Sie schließlich wieder zu Hause ankommen, stellen Sie eine Verbindung zur Datenbank her und aktualisieren diese mit den während Ihrer Reise vorgenommenen Änderungen.
Greifen Sie zunächst auf die Tabelle Authors zu, und speichern Sie sie.
'BeginSaveVB
'To integrate this code
'replace the data source and initial catalog values
'in the connection string
Public Sub Main()
On Error GoTo ErrorHandler
'recordset and connection variables
Dim rstAuthors As ADODB.Recordset
Dim Cnxn As ADODB.Connection
Dim strCnxn As String
Dim strSQLAuthors As String
' Open connection
Set Cnxn = New ADODB.Connection
strCnxn = "Provider='sqloledb';Data Source='MySqlServer';" & _
"Initial Catalog='Pubs';Integrated Security='SSPI';"
Cnxn.Open strCnxn
Set rstAuthors = New ADODB.Recordset
strSQLAuthors = "SELECT au_id, au_lname, au_fname, city, phone FROM Authors"
rstAuthors.Open strSQLAuthors, Cnxn, adOpenDynamic, adLockOptimistic, adCmdText
'For sake of illustration, save the Recordset to a diskette in XML format
rstAuthors.Save "c:\Pubs.xml", adPersistXML
' clean up
rstAuthors.Close
Cnxn.Close
Set rstAuthors = Nothing
Set Cnxn = Nothing
Exit Sub
ErrorHandler:
'clean up
If Not rstAuthors Is Nothing Then
If rstAuthors.State = adStateOpen Then rstAuthors.Close
End If
Set rstAuthors = Nothing
If Not Cnxn Is Nothing Then
If Cnxn.State = adStateOpen Then Cnxn.Close
End If
Set Cnxn = Nothing
If Err <> 0 Then
MsgBox Err.Source & "-->" & Err.Description, , "Error"
End If
End Sub
'EndSaveVB
At this point, you have arrived at your destination. Sie greifen als lokales, getrenntes Recordset-Objekt auf die Authors-Tabelle zu. Don't forget you must have the MSPersist provider on the machine that you are using in order to access the saved file, a:\Pubs.xml.
'BeginSave2VB
Public Sub Main()
On Error GoTo ErrorHandler
Dim rst As ADODB.Recordset
Set rst = New ADODB.Recordset
'For sake of illustration, we specify all parameters
rst.Open "c:\Pubs.xml", "Provider=MSPersist;", adOpenForwardOnly, adLockBatchOptimistic, adCmdFile
'Now you have a local, disconnected Recordset - Edit as you desired
'(In this example the change makes no difference)
rst.Find "au_lname = 'Carson'"
If rst.EOF Then
Debug.Print "Name not found."
Exit Sub
End If
rst!city = "Chicago"
rst.Update
'Save changes in ADTG format this time, purely for sake of illustration.
'Note that the previous version is still on the diskette, as a:\Pubs.xml.
rst.Save "c:\Pubs.adtg", adPersistADTG
' clean up
rst.Close
Set rst = Nothing
Exit Sub
ErrorHandler:
'clean up
If Not rst Is Nothing Then
If rst.State = adStateOpen Then rst.Close
End If
Set rst = Nothing
If Err <> 0 Then
MsgBox Err.Source & "-->" & Err.Description, , "Error"
End If
End Sub
'EndSave2VB
Schließlich kommen Sie wieder zu Hause an. Aktualisieren Sie nun die Datenbank mit Ihren Änderungen.
'BeginSave3VB
Public Sub Main()
On Error GoTo ErrorHandler
'To integrate this code
'replace the data source and initial catalog values
'in the connection string
Dim Cnxn As New ADODB.Connection
Dim rst As ADODB.Recordset
Dim strCnxn As String
Set rst = New ADODB.Recordset
' The lock mode is batch optimistic because we are going to
' use the UpdateBatch method.
rst.Open "c:\Pubs.adtg", "Provider=MSPersist;", adOpenForwardOnly, adLockBatchOptimistic, adCmdFile
' Connect to the database, associate the Recordset with the connection
' then update the database table with the changed Recordset
strCnxn = "Provider=SQLOLEDB;Data Source=MySqlServer;Integrated Security=SSPI;Initial Catalog=pubs;"
Cnxn.Open strCnxn
rst.ActiveConnection = Cnxn
rst.UpdateBatch
' clean up
rst.Close
Cnxn.Close
Set rst = Nothing
Set Cnxn = Nothing
Exit Sub
ErrorHandler:
'clean up
If Not rst Is Nothing Then
If rst.State = adStateOpen Then rst.Close
End If
Set rst = Nothing
If Not Cnxn Is Nothing Then
If Cnxn.State = adStateOpen Then Cnxn.Close
End If
Set Cnxn = Nothing
If Err <> 0 Then
MsgBox Err.Source & "-->" & Err.Description, , "Error"
End If
End Sub
'EndSave3VB