Tipos de datos
En 4D, los datos se manejan según su tipo en dos lugares: los campos de la base y el lenguaje 4D.
Aunque suelen ser equivalentes, algunos tipos de datos disponibles en la base no están disponibles directamente en el lenguaje y se convierten automáticamente. Por el contrario, algunos tipos de datos sólo pueden manejarse a través del lenguaje. La siguiente tabla lista todos los tipos de datos disponibles y cómo se soportan/declaran:
Tipos de datos | Soporte para la base (1) | Soporte para el lenguaje | Declaración de variables |
---|---|---|---|
Alfanumérico | Sí | Convertido en texto | - |
Text | Sí | Sí | C_TEXT , ARRAY TEXT |
Fecha | Sí | Sí | C_DATE , ARRAY DATE |
Hora | Sí | Sí | C_TIME , ARRAY TIME |
Boolean | Sí | Sí | C_BOOLEAN , ARRAY BOOLEAN |
Integer | Sí | Convertido en entero largo | ARRAY INTEGER |
Longint | Sí | Sí | C_LONGINT , ARRAY LONGINT |
Entero largo 64 bits | Sí (SQL) | Convertido en real | - |
Real | Sí | Sí | C_REAL , ARRAY REAL |
Indefinido | - | Sí | - |
Null | - | Sí | - |
Puntero | - | Sí | C_POINTER , ARRAY POINTER |
Picture | Sí | Sí | C_PICTURE , ARRAY PICTURE |
BLOB | Sí | Sí | C_BLOB , ARRAY BLOB |
Object | Sí | Sí | C_OBJECT , ARRAY OBJECT |
Collection | - | Sí | C_COLLECTION |
Variant(2) | - | Sí | C_VARIANT |
(1) Tenga en cuenta que ORDA maneja los campos de la base a través de objetos (entidades) y por lo tanto, sólo soporta los tipos de datos disponibles para estos objetos. Para más información, consulte la descripción del tipo de datos Objeto.
(2) La variante no es en realidad un tipo de datos sino un tipo de variable que puede contener un valor de cualquier otro tipo de datos.
Valores por defecto
Cuando las variables se introducen mediante una directiva del compilador, reciben un valor por defecto, que mantendrán durante la sesión mientras no hayan sido asignadas.
El valor por defecto depende del tipo y la categoría de la variable, su contexto de ejecución (interpretada o compilada), así como, para el modo compilado, las opciones de compilación definidas en la página Compilador de las Propiedades de la base:
- Las variables proceso e interproceso se ponen siempre "en cero" (lo que significa, según el caso, "0", una cadena vacía, un Blob vacío, un puntero Nil, una fecha en blanco (00-00-00), etc.)
- Se establecen las variables locales:
- en modo interpretado: en cero
- en modo compilado, dependiendo de la opción Inicializar variables locales de las Propiedades de la base:
- "en cero": en cero (ver arriba),
- "a un valor aleatorio": 0x72677267 para números y horas, siempre True para booleanos, igual que "en cero" para los demás,
- "no": no hay inicialización, lo que significa que lo que está en la RAM se utiliza para las variables, como los valores utilizados antes para otras variables. Nota: 4D recomienda utilizar "en cero".
La siguiente tabla ilustra estos valores por defecto:
Tipo | Interproceso/Proceso (interpretado/compilado), Local (interpretado/compilado "en cero") | Local compilado "aleatorio" | Local compilado "no" |
---|---|---|---|
Booleano | False | True | True (varía) |
Fecha | 00-00-00 | 00-00-00 | 00-00-00 |
Longint | 0 | 1919382119 | 909540880 (varía) |
Hora | 00:00:00 | 533161:41:59 | 249345:34:24 (varía) |
Picture | picture size=0 | picture size=0 | picture size=0 |
Real | 0 | 1.250753659382e+243 | 1.972748538022e-217 (varía) |
Puntero | Nil=true | Nil=true | Nil=true |
Text | "" | "" | "" |
Blob | Tamaño Blob=0 | Tamaño Blob=0 | Tamaño Blob=0 |
Object | null | null | null |
Collection | null | null | null |
Variant | indefinido | indefinido | indefinido |
Convertir los tipos de datos
El lenguaje 4D contiene operadores y comandos para convertir entre tipos de datos, cuando dichas conversiones tienen sentido. El lenguaje 4D aplica la verificación de tipos de datos. Por ejemplo, no se puede escribir: "abc"+0.5+!12/25/96!-?00:30:45?. Esto generará errores de sintaxis.
La siguiente tabla lista los tipos de datos básicos, los tipos de datos a los que se pueden convertir y los comandos utilizados para hacerlo:
Tipos a convertir | en Cadena | en Número | en Fecha | en Hora | en Booleano |
---|---|---|---|---|---|
String (1) | Num | Fecha | Hora | Bool | |
Número (2) | String | Bool | |||
Fecha | String | Bool | |||
Hora | String | Bool | |||
Boolean | Num |
(1) Las cadenas formateadas en JSON pueden convertirse en datos escalares, objetos o colecciones, utilizando el comando JSON Parse
.
(2) Los valores de tipo Hora pueden tratarse como números.
Nota: además de las conversiones de datos listadas en esta tabla, se pueden obtener conversiones de datos más sofisticadas combinando operadores y otros comandos.