Función ZONED( )
Convierte datos numéricos en datos de caracteres y agrega ceros a la izquierda de los datos de salida.
Nota
También puede usar la función LEADINGZEROS( ) para agregar ceros iniciales y, en muchos casos, esto es más sencillo que usar ZONED( ). Consulte Función LEADINGZEROS( ).
Sintaxis
ZONED(número; longitud)
Parámetros
Nombre | Tipo | Descripción |
---|---|---|
número |
numérico |
El valor numérico para convertir en una cadena. Nota Si desea agregar ceros iniciales a un valor de caracteres que contenga una cadena numérica, debe usar la función VALUE( ) para convertir los caracteres en datos de tipo numérico antes de usar el valor como datos de entrada para ZONED( ). Si desea obtener más información, consulte Función VALUE( ). |
longitud | numérico |
La longitud de la cadena de salida. |
Salida
Carácter.
Ejemplos
Ejemplos básicos
Información de entrada de íntegro
Devuelve "235":
ZONED(235; 3)
Devuelve "00235" porque longitud es mayor que el número de dígitos de número; por lo tanto, se agregan dos ceros al principio del resultado:
ZONED(235; 5)
Devuelve "35" porque longitud es menor que el número de dígitos de número; por lo tanto, el dígito ubicado más a la izquierda se quita del resultado:
ZONED(235; 2)
Información de entrada decimal
Devuelve "23585", porque el formato de datos zonados no admite un separador decimal:
ZONED(235,85; 5)
Valor de entrada negativo
Devuelve "64489M", porque el número es negativo y "M" representa el dígito final 4:
ZONED(-6448,94; 6)
Devuelve "489J", porque la longitud es inferior a la cantidad de dígitos del número; por lo tanto, los dos dígitos ubicados más a la izquierda se truncan del resultado y el número es negativo y "J" representa el dígito final 1:
ZONED(-6448,91; 4)
Ejemplos avanzados
Agregar ceros iniciales a un campo de caracteres que contiene números
El campo Número_de_empleado contiene el valor "254879". Debe convertir el valor en una cadena de 10 dígitos con ceros al principio.
Sugerencia
Debe utilizar la función VALUE( ) para convertir el carácter en datos numéricos antes de utilizar el numérico como datos de entrada para ZONED( ).
COMMENT devuelve "0000254879" ASSIGN v_largo_cadena = 10 ASSIGN v_cant_decimales = 0 ZONED(VALUE(Número_de_empleado; v_cant_decimales); v_largo_cadena)
Armonización de un campo clave al unir tablas
Usted tiene dos tablas, Ar y Cliente, y necesita unirlas por el campo NúmClien para realizar más análisis. Cada una de las dos tablas tiene un campo NúmClien, pero el formato de datos es diferente:
- Campo numérico Ar (por ejemplo, 235)
- Cliente campo de 5 caracteres que completa los números con ceros al principio (por ejemplo, "00235")
Para unificar los campos al unir, de manera que las longitudes y los tipos de datos sean iguales, utiliza la función ZONED( ) para convertir el campo clave Ar NúmClien a un campo de caracteres con una longitud de 5 para que coincida con el formato del campo clave en Cliente:
OPEN Ar PRIMARY OPEN Cliente SECONDARY JOIN PKEY ZONED (NúmClien;5) FIELDS NúmClien Vencimiento Monto SKEY NúmClien UNMATCHED TO Ar_Clien OPEN PRESORT SECSORT
Observaciones
Cómo funciona
Esta función convierte los datos numéricos en datos de caracteres y agrega ceros al inicio a la salida. La función se suele utilizar para unificar los campos que requieren ceros al inicio, por ejemplo, los campos de número de cheque, número de orden de compra y número de factura.
Cuándo usar ZONED( )
Utilice la función para convertir un valor numérico positivo en un valor de caracteres que contenga ceros al inicio. Esto es útil para la normalizar los datos en campos que se utilizarán como campos clave.
Por ejemplo, si una tabla contiene número de facturas con la forma 100 en un campo numérico y otra tabla contiene números de facturas con la forma "00100" en un campo de caracteres, puede utilizar ZONED( ) para convertir el valor numérico 100 en el valor de caracteres "00100". Esto permite comparar números de facturas semejantes.
Longitud de la cadena y valores de retorno
Los ceros al inicio se agregan al valor de salida cuando el valor longitud es mayor que el número de dígitos en número. Cuando longitud es menor que la cantidad de dígitos en número, la salida se trunca desde el lado izquierdo. Si el valor de número tiene la misma longitud que longitud, entonces no se agregan ceros.
Números decimales
El tipo de datos de zona no incluye una coma decimal explícita.
Números negativos
Si el número de valor de entrada es negativo, el dígito ubicado más a la derecha se muestra como un carácter en el resultado:
- "}" para 0
- una letra entre "J" y "R" para los dígitos 1 al 9
ZONED( ) y la edición Unicode de Analytics
Si trabaja con la edición Unicode de Analytics, es necesario utilizar la función BINTOSTR( ) para visualizar correctamente el valor devuelto de la función ZONED( ). También necesita utilizar la función BINTOSTR( ) si desea utilizar el valor devuelto de la función ZONED( ) como un parámetro en otra función.