适用于:Access 2013、Office 2013
设置或返回一个值,该值指定当设置 Field 对象的 Value 属性时是否立即验证该对象的值(仅适用于 Microsoft Access 工作区)。
语法
表达式 。ValidateOnSet
表达式 一个表示 Field 对象的变量。
说明
只有 Recordset 对象中的 Field 对象才支持可读写的 ValidateOnSet 属性。
当用户输入包含大量备注数据的记录时,将 ValidateOnSet 属性设置为 True 非常有用。 如果 Update 调用由于另一字段违反验证规则而显示数据无效,则等待该调用验证数据会将时间浪费在将冗长的备注数据写入数据库上。
示例
以下示例使用 ValidateOnSet 属性演示在数据输入过程中如何捕获错误。 若要使该过程运行,需要使用 ValidateData 函数。
Sub ValidateOnSetX()
Dim dbsNorthwind As Database
Dim fldDays As Field
Dim rstEmployees As Recordset
Set dbsNorthwind = OpenDatabase("Northwind.mdb")
' Create and append a new Field object to the Fields
' collection of the Employees table.
Set fldDays = _
dbsNorthwind.TableDefs!Employees.CreateField( _
"DaysOfVacation", dbInteger, 2)
fldDays.ValidationRule = "BETWEEN 1 AND 20"
fldDays.ValidationText = _
"Number must be between 1 and 20!"
dbsNorthwind.TableDefs!Employees.Fields.Append fldDays
Set rstEmployees = _
dbsNorthwind.OpenRecordset("Employees")
With rstEmployees
Do While True
' Add new record.
.AddNew
' Get user input for three fields. Verify that the
' data do not violate the validation rules for any
' of the fields.
If ValidateData(!FirstName, _
"Enter first name.") = False Then Exit Do
If ValidateData(!LastName, _
"Enter last name.") = False Then Exit Do
If ValidateData(!DaysOfVacation, _
"Enter days of vacation.") = False Then Exit Do
.Update
.Bookmark = .LastModified
Debug.Print !FirstName & " " & !LastName & _
" - " & "DaysOfVacation = " & !DaysOfVacation
' Delete new record because this is a demonstration.
.Delete
Exit Do
Loop
' Cancel AddNew method if any of the validation rules
' were broken.
If .EditMode <> dbEditNone Then .CancelUpdate
.Close
End With
' Delete new field because this is a demonstration.
dbsNorthwind.TableDefs!Employees.Fields.Delete _
fldDays.Name
dbsNorthwind.Close
End Sub
Function ValidateData(fldTemp As Field, _
strMessage As String) As Boolean
Dim strInput As String
Dim errLoop As Error
ValidateData = True
' ValidateOnSet is only read/write for Field objects in
' Recordset objects.
fldTemp.ValidateOnSet = True
Do While True
strInput = InputBox(strMessage)
If strInput = "" Then Exit Do
' Trap for errors when setting the Field value.
On Error GoTo Err_Data
If fldTemp.Type = dbInteger Then
fldTemp = Val(strInput)
Else
fldTemp = strInput
End If
On Error GoTo 0
If Not IsNull(fldTemp) Then Exit Do
Loop
If strInput = "" Then ValidateData = False
Exit Function
Err_Data:
If DBEngine.Errors.Count > 0 Then
' Enumerate the Errors collection. The description
' property of the last Error object will be set to
' the ValidationText property of the relevant
' field.
For Each errLoop In DBEngine.Errors
MsgBox "Error number: " & errLoop.Number & _
vbCr & errLoop.Description
Next errLoop
End If
Resume Next
End Function