Nota
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Se aplica a: Access 2013, Office 2013
Establece o devuelve el valor predeterminado de un objeto Field. Para un objeto Field que todavía no se ha anexado a la colección Fields, esta propiedad es de lectura y escritura (sólo áreas de trabajo de Microsoft Access).
Sintaxis
expresión . Defaultvalue
expression Variable que representa un objeto Field.
Comentarios
La configuración o el valor devuelto es un tipo de datos String que puede contener un máximo de 255 caracteres. Puede ser texto o una expresión. Si el valor de la propiedad es una expresión, no puede contener funciones definidas por el usuario, funciones de agregado SQL del motor de base de datos de Microsoft Access ni referencias a consultas, formularios u otros objetos Field.
Nota:
[!NOTA] También puede establecer la propiedad DefaultValue de un objeto Field en un objeto TableDef en un valor especial denominado "GenUniqueID( )". Esto provoca que se asigne un número aleatorio a este campo siempre que se agregue o se cree un nuevo registro, de ese modo se asigna cada registro a un identificador único. La propiedad Type del campo debe ser Long.
La disponibilidad de la propiedad DefaultValue depende del objeto que contiene la colección Fields, como se muestra en la siguiente tabla.
Si la colección Fields pertenece a |
Entonces DefaultValue |
---|---|
Objeto Index |
No está admitido |
Objeto QueryDef |
Solo lectura |
Objeto Recordset |
Solo lectura |
Objeto Relation |
No está admitido |
Objeto TableDef |
Lectura y escritura |
Cuando se crea un registro nuevo, el valor de la propiedad DefaultValue se especifica automáticamente como el valor del campo. Puede cambiar el valor del campo estableciendo su propiedad Value.
La propiedad DefaultValue no se aplica a los campos de tipo AutoNumber y Long Binary.
Ejemplo
En este ejemplo se utiliza la propiedad DefaultValue para advertir al usuario de un valor normal del campo mientras se le piden datos de entrada. Además, se demuestra cómo los registros nuevos se rellenarán utilizando DefaultValue en ausencia de cualquier otra entrada. Se requiere la función DefaultPrompt para que pueda ejecutarse este procedimiento.
Sub DefaultValueX()
Dim dbsNorthwind As Database
Dim tdfEmployees As TableDef
Dim strOldDefault As String
Dim rstEmployees As Recordset
Dim strMessage As String
Dim strCode As String
Set dbsNorthwind = OpenDatabase("Northwind.mdb")
Set tdfEmployees = dbsNorthwind.TableDefs!Employees
' Store original DefaultValue information and set the
' property to a new value.
strOldDefault = _
tdfEmployees.Fields!PostalCode.DefaultValue
tdfEmployees.Fields!PostalCode.DefaultValue = "98052"
Set rstEmployees = _
dbsNorthwind.OpenRecordset("Employees", _
dbOpenDynaset)
With rstEmployees
' Add a new record to the Recordset.
.AddNew
!FirstName = "Bruce"
!LastName = "Oberg"
' Get user input. If user enters something, the field
' will be filled with that data; otherwise, it will be
' filled with the DefaultValue information.
strMessage = "Enter postal code for " & vbCr & _
!FirstName & " " & !LastName & ":"
strCode = DefaultPrompt(strMessage, !PostalCode)
If strCode <> "" Then !PostalCode = strCode
.Update
' Go to new record and print information.
.Bookmark = .LastModified
Debug.Print " FirstName = " & !FirstName
Debug.Print " LastName = " & !LastName
Debug.Print " PostalCode = " & !PostalCode
' Delete new record because this is a demonstration.
.Delete
.Close
End With
' Restore original DefaultValue property because this is a
' demonstration.
tdfEmployees.Fields!PostalCode.DefaultValue = _
strOldDefault
dbsNorthwind.Close
End Sub
Function DefaultPrompt(strPrompt As String, _
fldTemp As Field) As String
Dim strFullPrompt As String
' Ask user for new DefaultValue setting for the specified
' Field object.
strFullPrompt = strPrompt & vbCr & _
"[Default = " & fldTemp.DefaultValue & _
", Cancel - use default]"
DefaultPrompt = InputBox(strFullPrompt)
End Function