LookUp - función de script
Lookup() mira en una tabla ya cargada y devuelve el valor de field_name correspondiente a la primera aparición del valor match_field_value en el campo match_field_name. La tabla puede ser la actual u otra cargada anteriormente.
Sintaxis:
lookup(field_name, match_field_name, match_field_value [, table_name])
Tipo de datos que devuelve: dual
Argumentos:
Argumento | Descripción |
---|---|
nombre_campo | Nombre del campo para el que se requiere el valor devuelto.El valor de entrada debe suministrarse como una cadena (por ejemplo, literales entrecomillados). |
match_field_name | Nombre del campo en el que buscar match_field_value. El valor de entrada debe suministrarse como una cadena (por ejemplo, literales entrecomillados). |
match_field_value | Valor que debe buscarse en el campomatch_field_name. |
table_name |
Nombre de la tabla en la que buscar el valor. El valor de entrada debe suministrarse como una cadena (por ejemplo, literales entrecomillados). Si table_name se omite, se da por sentado que se trata de la tabla actual. |
Limitaciones:
El orden de búsqueda es el orden de carga, a menos que la tabla sea el resultado de operaciones complejas, como uniones entre diversas tablas, en cuyo caso el orden no está bien definido. Tanto field_name como match_field_name deben ser campos de una misma tabla, la cual viene especificada mediante table_name.
Si no se encuentra ninguna correspondencia, se devuelve NULL.
Ejemplo:
Los datos de muestra utilizan la función Lookup() de la siguiente manera:
Lookup('Category', 'ProductID', ProductID, 'ProductList')
Añada el script de ejemplo a su documento y ejecútelo. A continuación, añada como mínimo los campos de la columna de resultados a una hoja de su documento para ver el resultado.
ProductList:
Load * Inline [
ProductID|Product|Category|Price
1|AA|1|1
2|BB|1|3
3|CC|2|8
4|DD|3|2
] (delimiter is '|');
OrderData:
Load *, Lookup('Category', 'ProductID', ProductID, 'ProductList') as CategoryID
Inline [
InvoiceID|CustomerID|ProductID|Units
1|Astrida|1|8
1|Astrida|2|6
2|Betacab|3|10
3|Divadip|3|5
4|Divadip|4|10
] (delimiter is '|');
Drop Table ProductList
En primer lugar se carga la tabla ProductList.
La función Lookup() se utiliza para crear la tabla OrderData. Especifica el tercer argumento como ProductID. Es el campo para el que debe buscarse el valor en el segundo argumento 'ProductID' en ProductList, tal como indica el entrecomillado simple utilizado.
La función devuelve el valor de “Category” (en la tabla ProductList), que se carga como CategoryID.
La sentencia drop elimina la tabla ProductList del modelo de datos porque no es necesaria y la tabla OrderData queda con el resultado siguiente:
ProductID | InvoiceID | CustomerID | Units | CategoryID |
---|---|---|---|---|
1 | 1 | Astrida | 8 | 1 |
2 | 1 | Astrida | 6 | 1 |
3 | 2 | Betacab | 10 | 2 |
3 | 3 | Divadip | 5 | 2 |
4 | 4 | Divadip | 10 | 3 |