Recordset2.LockEdits-Eigenschaft (DAO)
Gilt für: Access 2013, Office 2013
Legt einen Wert fest, der die Art der Sperrung angibt, die beim Bearbeiten wirksam ist, oder gibt diesen zurück.
Syntax
Ausdruck . LockEdits
Ausdruck Eine Variable, die ein Recordset2-Objekt darstellt.
Hinweise
Die Einstellung oder der Rückgabewert gibt den Sperrentyp an, wie in der folgenden Tabelle dargestellt.
Wert |
Beschreibung |
---|---|
Wahr |
Standard. Eine pessimistische Sperre wird verwendet. Die Seite mit dem aktuell bearbeiteten Datensatz wird gesperrt, sobald Sie die Edit-Methode aufrufen. |
Falsch |
Für die Bearbeitung wird die optimistische Sperre verwendet. Die Seite, die den Datensatz enthält, wird erst gesperrt, wenn die Update-Methode ausgeführt wird. |
Die LockEdits-Eigenschaft kann für aktualisierbare Recordset -Objekte verwendet werden.
Wenn eine Seite gesperrt ist, kann kein anderer Benutzer Datensätze auf der betreffenden Seite bearbeiten. Wenn Sie für LockEdits den Wert True festlegen und ein anderer Benutzer die Seite bereits gesperrt hat, tritt ein Fehler auf, wenn Sie die Edit-Methode verwenden. Andere Benutzer können Daten aus gesperrten Seiten einlesen.
Wenn Sie die LockEdits-Eigenschaft auf False festlegen und später die Update-Methode verwenden, während ein anderer Benutzer die Seite gesperrt hat, tritt ein Fehler auf. Um die Änderungen anzuzeigen, die von einem anderen Benutzer an Ihrem Datensatz vorgenommen wurden, verwenden Sie die Move-Methode mit 0 als Argument. Wenn Sie dies jedoch tun, gehen Ihre Änderungen verloren.
Bei der Arbeit mit odbc-Datenquellen, die mit der Microsoft Access-Datenbank-Engine verbunden sind, wird die LockEdits-Eigenschaft immer auf False oder optimistische Sperrung festgelegt. Das Microsoft Access-Datenbankmodul hat keine Kontrolle über die Sperrmechanismen, die in externen Datenbankservern verwendet werden.
Hinweis
Sie können den Wert von LockEdits beim ersten Öffnen des Recordset-Objekts voreinstellen, indem Sie das Lockedits-Argument der OpenRecordset-Methode festlegen. Durch Festlegen des lockedits-Arguments auf dbPessimistic wird die LockEdits-Eigenschaft auf True festgelegt, und wenn lockedits auf einen anderen Wert festgelegt wird, wird die LockEdits-Eigenschaft auf False festgelegt.
Beispiel
This example demonstrates pessimistic locking by setting the LockEdits property to True, and then demonstrates optimistic locking by setting the LockEdits property to False. It also demonstrates what kind of error handling is required in a multiuser database environment in order to modify a field. The PessimisticLock and OptimisticLock functions are required for this procedure to run.
Sub LockEditsX()
Dim dbsNorthwind As Database
Dim rstCustomers As Recordset2
Dim strOldName As String
Set dbsNorthwind = OpenDatabase("Northwind.mdb")
Set rstCustomers = _
dbsNorthwind.OpenRecordset("Customers", _
dbOpenDynaset)
With rstCustomers
' Store original data.
strOldName = !CompanyName
If MsgBox("Pessimistic locking demonstration...", _
vbOKCancel) = vbOK Then
' Attempt to modify data with pessimistic locking
' in effect.
If PessimisticLock(rstCustomers, !CompanyName, _
"Acme Foods") Then
MsgBox "Record successfully edited."
' Restore original data...
.Edit
!CompanyName = strOldName
.Update
End If
End If
If MsgBox("Optimistic locking demonstration...", _
vbOKCancel) = vbOK Then
' Attempt to modify data with optimistic locking
' in effect.
If OptimisticLock(rstCustomers, !CompanyName, _
"Acme Foods") Then
MsgBox "Record successfully edited."
' Restore original data...
.Edit
!CompanyName = strOldName
.Update
End If
End If
.Close
End With
dbsNorthwind.Close
End Sub
Function PessimisticLock(rstTemp As Recordset2, _
fldTemp As Field, strNew As String) As Boolean
dim ErrLoop as Error
PessimisticLock = True
With rstTemp
.LockEdits = True
' When you set LockEdits to True, you trap for errors
' when you call the Edit method.
On Error GoTo Err_Lock
.Edit
On Error GoTo 0
' If the Edit is still in progress, then no errors
' were triggered; you may modify the data.
If .EditMode = dbEditInProgress Then
fldTemp = strNew
.Update
.Bookmark = .LastModified
Else
' Retrieve current record to see changes made by
' other user.
.Move 0
End If
End With
Exit Function
Err_Lock:
If DBEngine.Errors.Count > 0 Then
' Enumerate the Errors collection.
For Each errLoop In DBEngine.Errors
MsgBox "Error number: " & errLoop.Number & _
vbCr & errLoop.Description
Next errLoop
PessimisticLock = False
End If
Resume Next
End Function
Function OptimisticLock(rstTemp As Recordset, _
fldTemp As Field, strNew As String) As Boolean
dim ErrLoop as Error
OptimisticLock = True
With rstTemp
.LockEdits = False
.Edit
fldTemp = strNew
' When you set LockEdits to False, you trap for errors
' when you call the Update method.
On Error GoTo Err_Lock
.Update
On Error GoTo 0
' If there is no Edit in progress, then no errors were
' triggered; you may modify the data.
If .EditMode = dbEditNone Then
' Move current record pointer to the most recently
' modified record.
.Bookmark = .LastModified
Else
.CancelUpdate
' Retrieve current record to see changes made by
' other user.
.Move 0
End If
End With
Exit Function
Err_Lock:
If DBEngine.Errors.Count > 0 Then
' Enumerate the Errors collection.
For Each errLoop In DBEngine.Errors
MsgBox "Error number: " & errLoop.Number & _
vbCr & errLoop.Description
Next errLoop
OptimisticLock = False
End If
Resume Next
End Function