Gestionar Datos

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 273

Gestión de datos

Qlik Sense®
June 2019
Copyright © 1993-2019 QlikTech International AB. Reservados todos los derechos.

HELP.QLIK.COM
© 2019 QlikTech International AB. All rights reserved. Qlik®, Qlik Sense®, QlikView®, QlikTech®, Qlik Cloud®, Qlik
DataMarket®, Qlik Analytics Platform®, Qlik NPrinting ®, Qlik Connectors®, Qlik GeoAnalytics®, Qlik Core®,
Associative Difference®, Lead with Data ™, Qlik Data Catalyst™, Qlik Associative Big Data Index™ and the QlikTech
logos are trademarks of QlikTech International AB that have been registered in one or more countries. Other
marks and logos mentioned herein are trademarks or registered trademarks of their respective owners.
Contents

1 Acerca de este documento 9


2 Gestión de datos 10
3 Administrar los datos de la app con el Gestor de datos 11
3.1 Ver una vista previa de una tabla de datos 11
3.2 Añadir una nueva tabla de datos 11
3.3 Editar una tabla de datos 12
3.4 Eliminar una tabla de datos 12
3.5 Gestionar las relaciones entre tablas de datos 13
3.6 Aplicar los cambios y cargar los datos 13
3.7 Las acciones Deshacer y Rehacer en el Gestor de datos 14
3.8 Ver los detalles de transformación de la tabla en el Gestor de datos 15
3.9 Interacción entre el Gestor de datos y el script de carga de datos 15
3.10 Concatenar tablas en el Gestor de datos 16
3.11 Añadir datos a la app 16
En app 17
Ubicaciones de archivo 17
Conexiones de datos 17
Contenido de datos 17
Adjuntar archivos a esta app 18
Conectar con una nueva fuente de datos 18
Añadir datos 18
¿De qué fuentes de datos dispongo? 18
Añadir datos desde una fuente de datos previa 18
Añadir datos de una nueva fuente de datos 21
Adjuntar archivos de datos y añadir los datos a la app 22
Añadir datos manualmente en Qlik Sense 26
Seleccionar datos de campos 28
Filtrar datos de archivos 34
Filtrar datos desde conectores de bases de datos 35
Añadir datos de Qlik DataMarket 36
3.12 Editar una tabla 49
Renombrar una tabla 50
Renombrar un campo 50
Gestionar las asociaciones con otras tablas 50
Cambiar el tipo de campo y el formato de presentación 51
Ocultar campos del análisis 51
Evaluar los datos de campos de tabla antes de cargar los datos 51
Reemplazar valores de campo en una tabla 52
Definir valores de campo como nulos en una tabla 52
Configurar un orden personalizado para los valores de campo 52
Dividir un campo en una tabla 52
Agrupar datos de medidas en rangos 52
Ver detalles de transformación de campo 53
Despivotar datos de tablas cruzadas 53

Gestión de datos - Qlik Sense, June 2019 3


Contents

Actualizar una tabla desde la fuente de datos 53


Añadir un campo calculado 53
Ordenar una tabla 54
Las acciones Deshacer y Rehacer 54
Asociar datos en el editor de tablas 54
Usar los campos calculados 56
Cambiar los tipos de campos 70
Ocultar campos del análisis 72
Evaluar los datos de campos de tabla antes de cargar los datos 73
Reemplazar valores de campo en una tabla 75
Definir valores de campo como nulos en una tabla 76
Personalizar el orden de los valores de dimensión 77
Dividir un campo en una tabla 78
Agrupar datos de medidas en rangos 81
Despivotar datos de una tabla cruzada en el gestor de datos 84
3.13 Concatenar tablas en el Gestor de datos 86
Concatenar tablas automáticamente 86
Forzar la concatenación entre tablas 87
Dividir tablas concatenadas 89
3.14 Ver los detalles de transformación de tablas y campos en el Gestor de datos 90
Ver los detalles de tabla 90
Ver los detalles de campo 91
3.15 Paso a paso: Combinar tablas usando concatenación forzada 91
La concatenación de un vistazo 91
Guía paso a paso: Concatenación forzada 91
Un paso más: agregar una nueva tabla y concatenar los campos de datos 98
3.16 Sincronizar tablas de script en el Gestor de datos 100
Sincronizar tablas de script 101
Eliminar las tablas de script gestionadas 101
3.17 Gestionar las asociaciones de datos 102
Asociar tablas usando el panel Asociaciones recomendadas 103
Asociar las tablas manualmente 104
Romper las asociaciones 105
Editar las asociaciones 106
Vista previa de los datos 106
Claves sintéticas 106
Limitaciones 107
Aplicar los cambios y volver a cargar los datos 107
4 Cargar datos con el script de carga de datos 109
4.1 Interacción entre el Gestor de datos y el script de carga de datos 109
4.2 Usar el editor de carga de datos 110
A: La barra de herramientas 111
B: Conexiones de datos 111
C: Editor de texto 111
D: Secciones 111

Gestión de datos - Qlik Sense, June 2019 4


Contents

E: Salida 111
Inicio rápido 111
Barras de herramientas 112
Conectar con fuentes datos en el editor de carga de datos 113
Seleccionar datos en el editor de carga de datos. 116
Editar el script de carga de datos 122
Organizar el código de script 126
Depurar el script de carga de datos 127
Guardar el script de carga 130
Ejecutar el script para cargar datos 130
Métodos abreviados de teclado en el Editor de carga de datos 131
4.3 Entender la sintaxis de script y las estructuras de datos 132
Extraer, transformar y cargar 132
Sentencias de carga de datos 133
Ejecución de script 134
Campos 134
Tablas lógicas 139
Tipos de datos de Qlik Sense 150
Expansiones de signo dólar 154
Uso de las comillas en el script 156
Utilización de caracteres comodín en los datos 160
Manejo de valores NULL 161
4.4 Directrices para datos y campos 164
Directrices para la cantidad máxima de datos cargados 164
Límites máximos de campos y tablas de datos 164
Límite recomendado para secciones de load script de carga 164
Convenciones para formatos numéricos y de tiempo 165
4.5 Trabajar con archivos QVD 168
Finalidad de los archivos QVD 169
Crear archivos QVD 169
Leer datos desde archivos QVD 170
Formato QVD 170
4.6 Gestionar la seguridad con sección de acceso 170
Secciones en el script 171
Reducción dinámica de datos 174
Restricciones de acceso heredadas 176
4.7 Configurar conexiones analíticas en Qlik Sense Desktop 176
Qlik repositorios SSE de código abierto 177
Descripción de los elementos 177
5 Gestionar grandes fuentes de datos big data con apps a demanda 178
5.1 Componentes de una app a demanda 178
5.2 Construir apps a demanda 179
5.3 Publicar apps a demanda (Windows) 180
5.4 Compartir apps a demanda (Kubernetes) 180
5.5 Ventajas de las apps a demanda 181

Gestión de datos - Qlik Sense, June 2019 5


Contents

5.6 Limitaciones 181


5.7 Crear una app de selección a demanda 181
5.8 Crear una app de plantilla a demanda 182
Estructura de una app de plantilla 183
Inicio de sesión único (SSO) 184
Cargar nodos para apps de plantilla 185
Expresiones de enlace en apps de plantilla a demanda 185
5.9 Construir una app a demanda 189
6 Conectar con fuentes de datos 193
6.1 Crear una conexión 193
6.2 Tipos de conexiones de datos 193
Adjuntar archivos 193
Qlik DataMarket 193
Conectores para bases de datos 194
Essbase 194
Archivos locales o en red 194
Conexiones ODBC mediante DSN 194
Qlik Associative Big Data Index 195
REST 195
Salesforce 195
SAP 195
Archivos web 195
Conectores de proveedores de almacenamiento web 195
Conectores de terceros 196
6.3 ¿Dónde se almacena la conexión de datos? 196
6.4 Limitaciones 196
6.5 Cargar datos desde archivos 196
¿Cómo puedo cargar datos desde archivos? 197
Cargar archivos desde carpetas de archivos locales y en red. 197
Cargar archivos desde recursos web 197
Cargar datos desde hojas de cálculo de Microsoft Excel 199
6.6 Cargar datos de bases de datos 201
Cargar datos desde una base de datos ODBC 201
ODBC 202
OLE DB 206
Lógica en bases de datos 207
6.7 Cargar datos desde Qlik DataMarket 208
6.8 Acceso a grandes conjuntos de datos con Direct Discovery 209
Diferencias entre datos Direct Discovery y datos en memoria 210
Tipos de campos de Direct Discovery 216
Fuentes de datos admitidas en Direct Discovery 217
Limitaciones de uso de Direct Discovery 218
Soporte multitabla en Direct Discovery 220
Utilizar subconsultas con Direct Discovery 222

Gestión de datos - Qlik Sense, June 2019 6


Contents

Acceso Direct Discovery de entrada 224


7 Ver el modelo de datos 226
7.1 La barra de herramientas 226
7.2 Mover y redimensionar tablas en el visor del modelo de datos 227
Mover tablas 227
Redimensionar tablas 228
7.3 Vista previa de tablas y campos en el visor del modelo de datos 228
Visualización de la vista previa de una tabla 229
Mostrar la vista previa de un campo 229
7.4 Crear una dimensión maestra en el visor del modelo de datos 230
7.5 Crear una medida maestra en el visor del modelo de datos 230
8 Mejores prácticas de modelado de datos 231
8.1 Convertir columnas de datos en filas 231
8.2 Convertir filas de datos en columnas 231
8.3 Cargar datos que están organizados en niveles jerárquicos, por ejemplo un diagrama de
flujo de una organización 232
8.4 Cargar solo registros nuevos o actualizados de una base de datos extensa 233
8.5 Combinar datos de dos tablas con un campo común 233
8.6 Asociar un valor discreto con un intervalo 233
8.7 Manejo de valores de campo inconsistentes 234
8.8 Manejo de mayúsculas inconsistentes en valores de campo 235
8.9 Cargar datos geoespaciales para visualizar los datos en un mapa 236
8.10 Cargar registros nuevos y actualizados mediante la carga incremental 236
Anexar solo 237
Insertar solo (no actualizar ni eliminar) 237
Insertar y actualizar (no eliminar) 238
Insertar, actualizar y eliminar 239
8.11 Combinar tablas con Join y Keep 240
Joins dentro de una sentencia SQL SELECT 241
Join 241
Keep 242
Inner 242
Left 243
Right 245
8.12 Usar la correspondencia como alternativa a la unión 246
8.13 Trabajar con tablas cruzadas en el editor de carga de datos 247
Despivotar una tabla cruzada con una columna cualificadora 248
Despivotar una tabla cruzada con dos columnas cualificadoras 249
8.14 Bases de datos genéricas 250
8.15 Emparejar intervalos con datos discretos 251
Ejemplo de intervalmatch 251
Utilizar la sintaxis ampliada de intervalmatch para resolver problemas de cambios de
dimensión progresivos 253

Gestión de datos - Qlik Sense, June 2019 7


Contents

8.16 Creación de un intervalo de fechas a partir de una sola fecha 255


8.17 Cargar datos jerárquicos 258
8.18 Cargar sus propios datos de mapa 259
Datos de nombre admitidos para campos en una visualización de mapa 259
Cargar datos de área y puntos desde un archivo KML 260
Cargar datos de mapa con perfilado de datos 260
Cargar y dar formato a datos de puntos 261
8.19 Limpieza de datos 263
Tablas de correspondencia 263
Utilizar una tabla de correspondencia 263
9 Resolución de problemas - Cargar datos 265
9.1 Una conexión de datos deja de funcionar después de reiniciar SQL Server 265
9.2 Advertencia de claves sintéticas al cargar los datos 265
9.3 Advertencia de referencias circulares al cargar los datos 266
9.4 Problemas de selección de datos con una fuente de datos OLE DB 266
9.5 Problemas de juego de caracteres con archivos de datos ANSI no codificados 266
9.6 El conector no funciona 267
El conector no está bien instalado 267
El conector no está adaptado para Qlik Sense 267
9.7 El script de carga de datos se ejecuta sin errores, pero los datos no se cargan 267
Una sentencia no termina en punto y coma 267
Usar comillas simples en una cadena 268
9.8 Las columnas no se alinean según lo esperado al seleccionar datos de un archivo de
registro fijo 268
9.9 Mensaje de error "Ruta no válida" al adjuntar un archivo 268
9.10 Errores al cargar una app convertida desde un documento QlikView 269
Referencias a rutas relativas utilizadas en el script 269
Funciones o sentencias no admitidas utilizadas en el script 269
9.11 Problemas para conectarse y cargar datos desde archivos Microsoft Excel a través de
ODBC 269
9.12 Adjuntar un archivo soltándolo en Añadir datos no funciona 270
9.13 Las tablas con campos comunes no se asocian automáticamente por nombre de campo 270
9.14 Los campos de fecha no se reconocen como campos de fecha en la vista de hoja 270
El perfilado de datos se deshabilitó al añadirse la tabla 271
El formato de fecha no se reconoce 271
9.15 El gestor de datos no muestra las tablas de la app que contienen datos 271
9.16 Los flujos de trabajo del gestor de datos se han roto para todos los usuarios que crean
apps en un servidor 272
9.17 Quedarse sin espacio en memoria 272
9.18 El editor de carga de datos no muestra el script 272

Gestión de datos - Qlik Sense, June 2019 8


1   Acerca de este documento

1 Acerca de este documento


Este documento describe cómo añadir y gestionar datos, cómo crear un script de carga de datos para modelos
de datos más avanzados, cómo visualizar el modelo de datos resultante en el visor del modelo de datos y
también analiza las mejores prácticas de modelado de datos en Qlik Sense.

Para obtener información más detallada sobre las funciones de script y las funciones de gráfico,
consulte la ayuda online de Sintaxis de script y funciones de gráficos.

Este documento está tomado de la ayuda online de Qlik Sense. Va destinado a aquellos que deseen leer partes
de la ayuda fuera de línea, sin conexión, o imprimir algunas páginas con facilidad y no incluye información
adicional alguna como sucede con la ayuda online.

Puede consultar la ayuda online, guías adicionales y mucho más en help.qlik.com/sense .

Gestión de datos - Qlik Sense, June 2019 9


2   Gestión de datos

2 Gestión de datos
Cuando ya haya creado una app de Qlik Sense, el primer paso será añadir algunos datos para poder
explorarlos y analizarlos. Esta sección describe cómo añadir y gestionar datos, cómo construir un script de
carga de datos para modelos de datos más avanzados, cómo visualizar el modelo de datos resultante en el
visor del modelo de datos y también analiza las mejores prácticas de modelado de datos en Qlik Sense.

Hay dos maneras de cargar datos en la app.

l Gestor de datos

Puede añadir datos de sus propias fuentes de datos, o de otras fuentes, como Qlik DataMarket sin tener
que aprender un lenguaje de script. Las selecciones de datos se pueden editar, y puede obtener ayuda en
la creación de las asociaciones de datos en su modelo de datos.

l Editor de carga de datos

Puede construir un modelo de datos con procesos ETL (Extract, Transform & Load) utilizando el lenguaje
de script de carga de datos Qlik Sense. El lenguaje de script es potente y le permite realizar
transformaciones complejas y crear un modelo de datos escalable.

Puede convertir un modelo de datos construido en el Gestor de datos en un script de carga de


datos, el cual podrá seguir desarrollando en el Editor de carga de datos, pero no es posible
convertir un script de carga de datos en un modelo de datos del Gestor de datos. El modelo de
datos del Gestor de datos y las tablas de datos definidas en el script de carga de datos aún pueden
coexistir, pero esto puede hacer más difícil la resolución de problemas en el modelo de datos.

Gestión de datos - Qlik Sense, June 2019 10


3   Administrar los datos de la app con el Gestor de datos

3 Administrar los datos de la app con el Gestor de


datos
Añada y administre datos desde el Gestor de datos para poder utilizar los datos en su app.

En el gestor de datos hay dos vistas:

l ▶ Asociaciones
Puede crear y editar asociaciones entre tablas.
l ' Tablas
Puede hacerse una idea de todas las tablas de datos de la app, tanto si las añadió utilizando Añadir
datos, como si las cargó con el script de carga de datos. Cada tabla se muestra con su nombre de tabla,
el número de campos de datos y el nombre de la fuente de datos.

3.1 Ver una vista previa de una tabla de datos


Puede acceder a una vista previa de una tabla para ver qué columnas contiene y un conjunto de muestra de los
datos.

Haga lo siguiente:

l Seleccione la tabla que desee ver.

Se muestra una vista previa del conjunto de datos de la tabla.

3.2 Añadir una nueva tabla de datos


Puede añadir rápidamente una tabla de datos a su app. Abra el Gestor de datos y después haga clic en ú .
También puede hacer clic en Añadir datos en el menú ¨  . También se le pedirá añadir datos cuando cree
una nueva app.

Puede añadir datos de las siguientes fuentes de datos:

Fuentes de datos
Fuente de
Descripción
datos

En app Seleccione de entre las fuentes de datos que están disponibles en su app. Pueden ser
archivos que haya adjuntado a la app.

También puede crear una fuente de datos y agregarle datos manualmente utilizando la
Entrada manual.

Ubicaciones de Seleccione de entre los archivos de una unidad de red, por ejemplo, de una unidad que
archivo haya definido su administrador.

Gestión de datos - Qlik Sense, June 2019 11


3   Administrar los datos de la app con el Gestor de datos

Fuente de
Descripción
datos

Conexiones de Seleccione de entre las conexiones de datos definidas por usted o un administrador.
datos

Contenido de Seleccione datos de fuentes normalizadas Qlik DataMarket procedentes de bases de


datos datos púbicas o comerciales.

3.3 Editar una tabla de datos


Puede editar todas las tablas de datos que haya añadido con Añadir datos. Puede renombrar la tabla y los
campos en la tabla de datos y actualizar los campos de la fuente de datos. También se puede añadir un campo
calculado y ajustar los formatos de fecha y hora.

Haga lo siguiente:

1. Haga clic en @ en la tabla de datos que desee editar.


Se abre el editor de tabla de datos y puede realizar las ediciones y transformaciones que desee.
2. Haga clic en Cerrar para regresar.

La tabla queda marcada ahora como Pendiente de actualizar y los cambios se aplicarán a los datos de la
app la próxima vez que cargue los datos.

Solo puede editar tablas de datos añadidas mediante Añadir datos. Si hace clic en @ en una tabla
que se cargó usando el script de carga, se abre el editor de carga de datos. Para más información,
vea Usar el editor de carga de datos (page 110).

3.4 Eliminar una tabla de datos


Solo puede eliminar tablas de datos que se hayan añadido mediante Añadir datos. Las tablas de datos que se
hayan cargado usando el script de carga solo pueden eliminarse editando el script en el editor de carga de
datos.
Haga lo siguiente:

l Haga clic en Ö en la tabla de datos que desee eliminar.

La tabla se ha marcado ahora para su eliminación como Pendiente de eliminar y se eliminará la próxima
vez que cargue los datos.

Puede deshacer y rehacer sus acciones de eliminación haciendo clic en B y C .

Si ha utilizado campos de la tabla de datos en una visualización, eliminar la tabla de datos dará
como resultado un error que se muestra en la app.

Gestión de datos - Qlik Sense, June 2019 12


3   Administrar los datos de la app con el Gestor de datos

3.5 Gestionar las relaciones entre tablas de datos


Cuando añada varias tablas que necesiten asociarse, la situación perfecta sería que las tablas se asocien con
campos clave que tengan nombres idénticos en las distintas tablas. Si ese es el caso, puede añadirlas a Qlik
Sense con la opción de Añadir datos deshabilitada en el perfilado de datos y el resultado será una estructura
de datos con las tablas asociadas correctamente.

Si tiene un número menor de fuentes de datos de lo que sería ideal, puede que se encuentre con algunos
problemas de asociación.

l Si hemos cargado dos campos que contienen los mismos datos pero nombres de campo diferentes en
dos tablas, probablemente sea una buena idea nombrar ambos campos de idéntica forma para que las
tablas se asocien.
l Si hemos cargado dos campos que contienen datos diferentes pero poseen nombres de campo idénticos
en dos tablas diferentes, necesitaremos renombrar al menos uno de los campos para cargarlos como
campos aparte, distintos uno de otro.
l Si hemos cargado dos tablas que contienen más de un campo en común.

Si desea asociar sus datos, le recomendamos que utilice la opción Añadir datos con el perfilado de datos
habilitado. Esta es la opción predeterminada. Puede verificar esta configuración haciendo clic en ¥  junto al
botón Añadir datos en la esquina inferior derecha de la página Añadir datos.

Qlik Sense efectúa un perfilado de los datos que deseamos cargar para ayudarnos a reparar las asociaciones
entre tablas. Las malas asociaciones y aquellas potencialmente buenas se resaltan y recibimos ayuda en la
selección de campos que asociar, basándose en un análisis de los datos.

Las asociaciones entre tablas se pueden gestionar de dos maneras diferentes:

l En la vista ▶ Asociaciones del gestor de datos.


Puede crear asociaciones basadas en las recomendaciones o crear asociaciones personalizadas basadas
en uno o más campos.
l Utilizando la opción Asociar del editor de tabla.
Puede crear asociaciones personalizadas y asociaciones de claves compuestas basadas en varios
campos.

Si deshabilita el perfilado de datos cuando se están añadiendo datos, Qlik Sense automáticamente
asociará tablas basadas en nombres de campo comunes.

3.6 Aplicar los cambios y cargar los datos


Los cambios que haya efectuado en el Gestor de datos no estarán disponibles en la app hasta que haya
cargado los datos. Cuando carga los datos, se aplican los cambios y cualquier dato nuevo que haya añadido se
carga desde las fuentes de datos externas. Los datos que haya cargado previamente no se cargan.

Gestión de datos - Qlik Sense, June 2019 13


3   Administrar los datos de la app con el Gestor de datos

Puede volver a cargar todos los datos de las fuentes externas de datos utilizando el botón ô en el pie de
página del Gestor de datos.

El botón ô carga todos los datos de la tabla seleccionada. No carga todos los datos de todas las tablas de la
app.

Si los datos del Gestor de datos no están sincronizados con los datos de la app, el botón Cargar datos se
muestra de color verde. En la vista Asociaciones, todas las tablas nuevas o actualizadas se indican mediante un
asterisco * y las tablas eliminadas se ven de un color gris más claro. En la vista Tablas, todas las tablas nuevas,
actualizadas o eliminadas se destacan de color azul y muestran un icono que indica el estado de la tabla:

l Las tablas marcadas con Pendiente de eliminar Ö se eliminarán.


l Las tablas marcadas con Pendiente de actualizar ô se actualizarán con campos que se hayan
añadido, cambiado de nombre o eliminado, o se cambiará el nombre de la tabla.
l Las tablas marcadas con Pendiente de añadir m se añadirán.

Haga lo siguiente:

l Haga clic en Cargar datos para cargar los cambios en la app.

Los datos de la app se actualizan ahora con los cambios que realizó en el Gestor de datos.

Para aplicar los cambios y cargar todos los datos en la tabla seleccionada desde fuentes de datos externas:

Haga lo siguiente:

l Haga clic en el botón ô en el pie de página del Gestor de datos.

3.7 Las acciones Deshacer y Rehacer en el Gestor de datos


Cuando esté editando en el Gestor de datos, puede deshacer o rehacer algunas acciones haciendo clic en B y
C o utilizando los métodos abreviados de teclado Ctrl + Z y Ctrl + Y.

El registro de acciones se borra si:

l Cambiamos de vista, por ejemplo, vamos de la vista general de tablas a la de Asociaciones.


l Cargamos datos.
l Cerramos el Gestor de datos.

Gestión de datos - Qlik Sense, June 2019 14


3   Administrar los datos de la app con el Gestor de datos

3.8 Ver los detalles de transformación de la tabla en el


Gestor de datos
Puede ver las operaciones y transformaciones realizadas en una tabla en el Gestor de datos utilizando el
diálogo Detalles. El diálogo Detalles está disponible en las vistas de Asociaciones y Tabla.

Detalles muestra las operaciones actuales y las transformaciones realizadas en la tabla seleccionada. Esto le
muestra el origen de una tabla, los cambios actuales que se han realizado y la secuencia en la que se han
aplicado los cambios. Detalles le permite comprender más fácilmente cómo llegó una tabla a su estado actual.
Puede usar Detalles, por ejemplo, para ver fácilmente el orden en que se concatenaron las tablas.

3.9 Interacción entre el Gestor de datos y el script de carga


de datos
Cuando añadimos tablas de datos en el Gestor de datos, se genera un código de script de carga. Podemos ver
el código de script en la Sección generada automáticamente del editor de carga de datos. También podemos
desbloquear y editar el código de script generado, pero si lo hacemos, las tablas de datos ya no se podrán
gestionar más desde el Gestor de datos.

Las tablas de datos definidas en el script de carga no se gestionan desde el Gestor de datos de forma
predeterminada. Es decir, podremos ver las tablas en la vista general de datos, pero no podremos eliminar o
editar las tablas en el Gestor de datos, y no se ofrecen recomendaciones de asociaciones para tablas cargadas
mediante el script. Si sincroniza sus tablas de script con el Gestor de datos no obstante, sus tablas de script se
añadirán como tablas de script gestionadas al Gestor de datos.

Si tiene tablas sincronizadas, no debe realizar cambios en el editor de carga de datos con el Gestor
de datos abierto en otra pestaña.

Podemos añadir secciones al script y desarrollar código que mejore e interactúe con el modelo de datos creado
en el Gestor de datos, pero hay algunas áreas en las que debemos ir con cuidado. El código de script que
escribamos puede interferir con el modelo de datos del Gestor de datos y crear problemas en los siguientes
casos:

l Renombrar o eliminar tablas añadidas con el Gestor de datos en el script.


l Eliminar campos de tablas añadidas con el Gestor de datos.
l Concatenación entre tablas añadidas con el Gestor de datos y tablas cargadas en el script.
l Utilizar la sentencia Qualify con campos en tablas añadidas con el Gestor de datos.
l Cargar tablas añadidas con el Gestor de datos utilizando Resident en el script.
l Añadir código de script tras la sección de código generada. Los cambios resultantes en el modelo de
datos no se reflejan en el Gestor de datos.

Gestión de datos - Qlik Sense, June 2019 15


3   Administrar los datos de la app con el Gestor de datos

3.10 Concatenar tablas en el Gestor de datos


La concatenación combina dos tablas en una sola tabla con campos combinados. Consolida el contenido,
reduciendo así el número de tablas y campos que comparten contenido. Las tablas del Gestor de datos se
pueden concatenar automáticamente o de manera forzada.

Tabla concatenada en la vista de Tablas y en la vista de Asociaciones.

3.11 Añadir datos a la app


Puede añadir datos a su app rápidamente. Abra el Gestor de datos y después haga clic en ú . También puede
hacer clic en Añadir datos en el menú ¨  . También se le pedirá añadir datos cuando cree una nueva app.
Cuando está editando una hoja, también puede hacer clic en Añadir en el panel de Campos para añadir datos.

Las opciones para añadir datos y las fuentes de datos que tiene disponibles dependen de su
configuración y plataforma de Qlik Sense.

Vista para añadir datos en Qlik Sense Enterprise on Windows

Gestión de datos - Qlik Sense, June 2019 16


3   Administrar los datos de la app con el Gestor de datos

En app
Archivos adjuntos. Plataformas: Qlik Sense Enterprise on Windows, Qlik Sense Cloud Business. Haga clic para
ver los archivos adjuntos a la app. Puede cargar datos de estos archivos.

Entrada manual. Plataformas: todas. Haga clic para crear una tabla en la app y añadirla al Gestor de datos.

Ubicaciones de archivo
Archivos de datos. Plataformas: Qlik Cloud Services, Kubernetes, Qlik Sense Cloud Business.

Archivos de datos compartidos. Plataformas: Qlik Sense Enterprise on Windows. Esta carpeta aparece si su
administrador ha definido una carpeta de red que contiene archivos compartidos.

Mi ordenador. Plataformas: Qlik Sense Desktop

Haga clic para cargar un archivo de datos o bien para añadir datos procedentes de un archivo que ya se ha
cargado.

Conexiones de datos
Plataformas: todas.

Muestra las conexiones que se han creado a una fuente de datos externa. La conexión aparece después de
haberla creado en Conectar con una nueva fuente de datos.

Haga clic en una conexión para añadir datos a la app.

Contenido de datos
Qlik DataMarket. Plataformas: Qlik Sense Enterprise on Windows, Qlik Sense Cloud Business, Qlik Sense
Desktop.

Gestión de datos - Qlik Sense, June 2019 17


3   Administrar los datos de la app con el Gestor de datos

Las fuentes de Qlik DataMarket que están disponibles para el usuario dependen de su suscripción.

Haga clic para añadir datos a la app.

Adjuntar archivos a esta app


Haga clic para adjuntar un archivo a la app.

Conectar con una nueva fuente de datos


Haga clic para crear una conexión a una nueva fuente de datos.

Añadir datos
Haga clic para añadir datos a una app. El botón se habilitará después de haber creado una conexión y haber
seleccionado los datos que desea cargar. Puede añadir datos con el perfilado de datos habilitado o
deshabilitado. Recomendamos que el perfilado de datos esté habilitado y esta es la opción por defecto. Haga clic
en ¥ para deshabilitar el perfilado de datos.

¿De qué fuentes de datos dispongo?


El tipo de fuentes de datos disponibles depende de varios factores:

l Configuraciones de acceso:
Los parámetros de administrador determinan a qué tipos de fuentes de datos podemos conectarnos.
l Conectores instalados
Qlik Sense incorpora soporte para muchas fuentes de datos. Los conectores incorporados son instalados
automáticamente por Qlik Sense. Para conectar con fuentes de datos adicionales puede que necesite
instalar conectores aparte, específicos para esas fuentes de datos. Dichos conectores que se instalan
aparte son suministrados por Qlik o un tercero.
l Disponibilidad de archivos locales.
Los archivos locales de su ordenador de escritorio solo están disponibles en Qlik Sense Desktop. No están
disponibles para su uso en una instalación de servidor de Qlik Sense.

Si tiene archivos locales que desee cargar en una instalación de servidor de Qlik Sense,
necesita adjuntar los archivos a la app o transferir los archivos a una carpeta que esté
disponible para el servidor de Qlik Sense, preferentemente una carpeta que ya se haya
definido mediante una conexión de datos de carpetas.

Añadir datos desde una fuente de datos previa


Puede añadir datos a su app de conexiones que ya haya definido previamente usted o un administrador. Pueden
ser una base de datos, una carpeta que contenga archivos de datos o un conector a una fuente de datos
externa, como Salesforce.com.

Gestión de datos - Qlik Sense, June 2019 18


3   Administrar los datos de la app con el Gestor de datos

No agregue una tabla en el Gestor de datos que ya se haya agregado como una tabla con
secuencias de script con el mismo nombre y las mismas columnas de datos en el Editor de carga
de datos.

Puede eliminar conexiones desde Añadir datos haciendo clic con el botón derecho en la conexión y
seleccionando Ö Eliminar conexión.

Si elimina una conexión, debe eliminar cualquier tabla del Gestor de datos que utilizó esa conexión
antes de cargar los datos.

Haga lo siguiente:

1. Abra su app.
2. Abra el Gestor de datos y después haga clic en ú . También puede hacer clic en Añadir datos en el
menú ¨  .
3. En Conexiones de datos, seleccione una conexión existente.
Algunas conexiones van directas a las fuentes de datos, donde puede seleccionar las tablas y campos que
desee cargar. Por ejemplo, las conexiones a Salesforce.com o una base de datos, como IBM DB2, van
directamente a la fuente para la selección de datos.
4. Seleccione la fuente de datos específica desde la que desea añadir datos si la conexión le ofrece una
selección.
Esto difiere dependiendo del tipo de fuente de datos.
l Fuentes de datos basadas en archivos: Seleccione un archivo.
l Bases de datos: Define qué base de datos usar.
l Archivos web: Escriba la URL del archivo web.
l Otras fuentes de datos: Especificado por el conector.
5. Seleccione las tablas y los campos que desee cargar.
6. Opcionalmente también puede aplicar un filtro de datos si desea seleccionar un subconjunto de los datos
contenidos en los campos que ha seleccionado.
Si su fuente de datos es un archivo, seleccione Filtros. Junto a la tabla a la que desea agregar un filtro,
haga clic en Añadir filtro, seleccionar un campo, seleccionar una condición y después introduzca un
valor con el que filtrar.

Qlik Sense no admite filtros en campos de fecha desde archivos QVD .

Tenga en cuenta lo siguiente:


l Puede aplicar múltiples filtros al mismo campo.
l Puede eliminar filtros en la vista Asociaciones del Gestor de datos o desde Seleccionar datos
desde su origen. Para que los cambios surtan efecto, vuelva a cargar los datos haciendo clic en el
botón Cargar datos.

Gestión de datos - Qlik Sense, June 2019 19


3   Administrar los datos de la app con el Gestor de datos

Con las bases de datos y conectores, cuando seleccione Filtrar datos, se abrirá un cuadro de texto para
los criterios de filtro.
Tenga en cuenta lo siguiente:
l Se aplican filtros a los nombres de los campos de la base de datos. Si cambia el nombre de un
campo en el Gestor de datos, tiene que aplicar el filtro al nombre original del campo en la base
de datos. Por ejemplo, si un campo se denomina EMP en su base de datos y usted lo redenomina
EMPLOYEE en el Gestor de datos, tendrá que aplicar el filtro EMP = ‘filter_value’.
l Puede borrar los filtros de datos en la vista Asociaciones del Gestor de datos. Para que los
cambios surtan efecto, cargue los datos haciendo clic en el botón Cargar datos. Debe dividir las
tablas concatenadas antes de borrar los filtros.
l Filtrar datos no está disponible actualmente para todos los conectores ni para los archivos
adjuntos. Filtrar tampoco está disponible para Qlik DataMarket.
7. Haga clic en Añadir datos para abrir los datos en la vista Asociaciones del gestor de datos. Esto le
permite continuar añadiendo fuentes de datos, transformar los datos y asociar las tablas en el Gestor
de datos.
El perfilado de datos está activo por defecto al hacer clic en Añadir datos. El perfilado de datos hace lo
siguiente:
l Recomienda asociaciones de datos.
l Califica automáticamente los campos comunes entre tablas. Esto agrega un prefijo único basado
en el nombre de la tabla.
l Asigna los campos de fecha y hora a autoCalendar.
Las tablas no se asocian automáticamente en los nombres de campos comunes. Puede asociar tablas en
la vista Asociaciones.

Si desea cargar los datos directamente en su app, haga clic en ¥  y después desactive el
perfilado de datos. Esto cargará los datos recién seleccionados de la fuente de datos externa
cuando agregue datos. Las tablas se asociarán automáticamente en los nombres de
campos comunes. Los campos de fecha y hora no se crearán.

Para más información, vea Gestionar las asociaciones de datos (page 102).
8. Haga clic en Cargar datos cuando haya terminado de preparar los datos. Si se detectaran problemas
serios, debe resolverlos en el Gestor de datos antes de poder cargar datos en la app.
Para más información, vea Resolución de problemas - Cargar datos (page 265).

Para volver a cargar todos los datos que ha seleccionado de la fuente externa, use el botón ô en el pie de
página del Gestor de datos. Esto le asegura que obtiene todos los datos actuales de la fuente para las
selecciones que ha realizado. Recargar todos los datos puede llevar más tiempo que cargar solo los nuevos
datos. Si los datos cargados previamente no se han modificado en el origen de datos, no es necesario recargar
todos los datos.

Gestión de datos - Qlik Sense, June 2019 20


3   Administrar los datos de la app con el Gestor de datos

Añadir datos de una nueva fuente de datos


Puede añadir datos a la app procedentes de una nueva fuente de datos. Cuando añade datos de una nueva
fuente de datos, se crea una conexión a la fuente de datos en Conexiones de datos, lo que facilita agregar más
datos de la misma fuente de datos.

No agregue una tabla en el Gestor de datos que ya se haya agregado como una tabla con
secuencias de script con el mismo nombre y las mismas columnas de datos en el Editor de carga
de datos.

Puede eliminar conexiones desde Añadir datos haciendo clic con el botón derecho en la conexión y
seleccionando Ö Eliminar conexión.

Si elimina una conexión, debe eliminar cualquier tabla del Gestor de datos que utilizó esa conexión
antes de cargar los datos.

Haga lo siguiente:

1. Abra una app.


2. Abra el Gestor de datos y después haga clic en ú . También puede hacer clic en Añadir datos en el
menú ¨  .
3. En Conectar con una nueva fuente de datos, seleccione una fuente.
4. Introduzca los parámetros de conexión requeridos por la fuente de datos.
Por ejemplo:
l Las fuentes de datos basadas en archivos requieren que se especifique una ruta de acceso a los
archivos y seleccionar un tipo de archivo.
l Bases de datos como Oracle y IBM DB2 requieren propiedades de base de datos y credenciales de
acceso.
l Los archivos web requieren la URL del archivo web.
l Las conexiones ODBC requieren credenciales DSN.
5. Seleccione las tablas y los campos que desee cargar.
6. Opcionalmente también puede aplicar un filtro de datos si desea seleccionar un subconjunto de los datos
contenidos en los campos que ha seleccionado.
Si su fuente de datos es un archivo, seleccione Filtros. Junto a la tabla a la que desea agregar un filtro,
haga clic en Añadir filtro, seleccionar un campo, seleccionar una condición y después introduzca un
valor con el que filtrar.

Qlik Sense no admite filtros en campos de fecha desde archivos QVD .

Tenga en cuenta lo siguiente:

Gestión de datos - Qlik Sense, June 2019 21


3   Administrar los datos de la app con el Gestor de datos

l Puede aplicar múltiples filtros al mismo campo.


l Puede eliminar filtros en la vista Asociaciones del Gestor de datos o desde Seleccionar datos
desde su origen. Para que los cambios surtan efecto, vuelva a cargar los datos haciendo clic en el
botón Cargar datos.
Con las bases de datos y conectores, cuando seleccione Filtrar datos, se abrirá un cuadro de texto para
los criterios de filtro.
Tenga en cuenta lo siguiente:
l Se aplican filtros a los nombres de los campos de la base de datos. Si cambia el nombre de un
campo en el Gestor de datos, tiene que aplicar el filtro al nombre original del campo en la base
de datos. Por ejemplo, si un campo se denomina EMP en su base de datos y usted lo redenomina
EMPLOYEE en el Gestor de datos, tendrá que aplicar el filtro EMP = ‘filter_value’.
l Puede borrar los filtros de datos en la vista Asociaciones del Gestor de datos. Para que los
cambios surtan efecto, cargue los datos haciendo clic en el botón Cargar datos. Debe dividir las
tablas concatenadas antes de borrar los filtros.
l Filtrar datos no está disponible actualmente para todos los conectores ni para los archivos
adjuntos. Filtrar tampoco está disponible para Qlik DataMarket.
7. Haga clic en Añadir datos para abrir los datos en la vista Asociaciones del gestor de datos. Esto le
permite continuar añadiendo fuentes de datos, transformar los datos y asociar las tablas en el Gestor
de datos.
El perfilado de datos está activo por defecto al hacer clic en Añadir datos. El perfilado de datos hace lo
siguiente:
l Recomienda asociaciones de datos.
l Califica automáticamente los campos comunes entre tablas. Esto agrega un prefijo único basado
en el nombre de la tabla.
l Asigna los campos de fecha y hora a autoCalendar.
Las tablas no se asocian automáticamente en los nombres de campos comunes. Puede asociar tablas en
la vista Asociaciones.

Si desea cargar los datos directamente en su app, haga clic en ¥  y después desactive el
perfilado de datos. Esto cargará también todos los datos existentes de fuentes de datos
cuando agregue los datos. Las tablas se asociarán automáticamente en los nombres de
campos comunes. Los campos de fecha y hora no se crearán.

Para más información, vea Gestionar las asociaciones de datos (page 102).
8. Haga clic en Cargar datos cuando haya terminado de preparar los datos. Si se detectaran problemas
serios, debe resolverlos en el Gestor de datos antes de poder cargar datos en la app.
Para más información, vea Resolución de problemas - Cargar datos (page 265).

Adjuntar archivos de datos y añadir los datos a la app


Puede adjuntar archivos de datos a su app y, a continuación, usarlos en la app.

Gestión de datos - Qlik Sense, June 2019 22


3   Administrar los datos de la app con el Gestor de datos

Esta funcionalidad no está disponible en Kubernetes.

Un archivo adjunto solo está disponible en la app a la que se adjunta. No hay conexión con su archivo de datos
original, así que si actualizó el archivo original debe actualizar el archivo adjunto.

Para evitar exponer datos restringidos, elimine todos los archivos adjuntos con la configuración de
sección de acceso antes de publicar la app.

Los archivos adjuntos se incluyen cuando la app se publica. Si la app publicada se copia, los
archivos adjuntos se incluyen en la copia. Sin embargo, si se han aplicado restricciones de sección
de acceso a los archivos de datos adjuntos, la configuración de la sección de acceso no se conserva
al copiarse los archivos, por lo que los usuarios de la app copiada podrán ver todos los datos en los
archivos adjuntos.

Limitaciones
l El tamaño máximo de un archivo adjunto a la app es de 50 MB.
l El tamaño total máximo de los archivos adjuntos a la app, incluidos los archivos de imagen cargados en
la biblioteca de medios multimedia, es de 200 MB.
l No es posible adjuntar archivos en Qlik Sense Desktop.

Adjuntar varios archivos de datos rápidamente


La forma más rápida y en la mayoría de los casos, la más fácil de adjuntar y añadir un conjunto de archivos de
datos a su app consiste simplemente en soltar los archivos en la aplicación.

Haga lo siguiente:

l Suelte uno o más archivos de datos en su app.


Los archivos se cargan y adjuntan a la app, y se añaden al modelo de datos.

Al adjuntar archivos de esta manera Qlik Sense tratará de seleccionar los ajustes óptimos para la carga de
datos, por ejemplo, reconociendo los nombres de campos incrustados, los delimitadores de campos o conjuntos
de caracteres. Si se agregara una tabla con parámetros que no son óptimos se puede corregir la configuración
abriendo la tabla en el editor de tablas, y haciendo clic en Seleccionar datos de la fuente.

No es posible soltar los archivos en el editor de carga de datos o en el visor de modelo de datos.

Adjuntar un solo archivo de datos


Puede adjuntar los archivos de datos de uno en uno. De esta manera se obtiene un mayor control sobre la
configuración de importación de archivos, por ejemplo, los nombres de los campos incrustados, delimitadores
de campo o conjuntos de caracteres utilizados.

Gestión de datos - Qlik Sense, June 2019 23


3   Administrar los datos de la app con el Gestor de datos

No agregue una tabla en el Gestor de datos que ya se haya agregado como una tabla con
secuencias de script con el mismo nombre y las mismas columnas de datos en el Editor de carga
de datos.

Haga lo siguiente:

1. Abra una app.


2. Abra el Gestor de datos y después haga clic en ú . También puede hacer clic en Añadir datos en el
menú ¨  .
3. Arrastre un archivo de datos, o haga clic y seleccione un archivo de su ordenador para cargarlo.
Si trata de ajuntar un archivo con el mismo nombre que un archivo ya adjuntado, recibirá la opción de
reemplazar el archivo adjunto por el nuevo archivo.

Cada archivo adjunto necesita tener un nombre único de archivo.

4. Seleccione las tablas y los campos que desee cargar.


5. Opcionalmente también puede aplicar un filtro de datos si desea seleccionar un subconjunto de los datos
contenidos en los campos que ha seleccionado.
Si su fuente de datos es un archivo, seleccione Filtros. Junto a la tabla a la que desea agregar un filtro,
haga clic en Añadir filtro, seleccionar un campo, seleccionar una condición y después introduzca un
valor con el que filtrar.

Qlik Sense no admite filtros en campos de fecha desde archivos QVD .

Tenga en cuenta lo siguiente:


l Puede aplicar múltiples filtros al mismo campo.
l Puede eliminar filtros en la vista Asociaciones del Gestor de datos o desde Seleccionar datos
desde su origen. Para que los cambios surtan efecto, vuelva a cargar los datos haciendo clic en el
botón Cargar datos.
6. Haga clic en Añadir datos para abrir los datos en la vista Asociaciones del gestor de datos. Esto le
permite continuar añadiendo fuentes de datos, transformar los datos y asociar las tablas en el Gestor
de datos.
El perfilado de datos está activo por defecto al hacer clic en Añadir datos. El perfilado de datos hace lo
siguiente:
l Recomienda asociaciones de datos.
l Califica automáticamente los campos comunes entre tablas. Esto agrega un prefijo único basado
en el nombre de la tabla.
l Asigna los campos de fecha y hora a autoCalendar.
Las tablas no se asocian automáticamente en los nombres de campos comunes. Puede asociar tablas en
la vista Asociaciones.

Gestión de datos - Qlik Sense, June 2019 24


3   Administrar los datos de la app con el Gestor de datos

Si desea cargar los datos directamente en su app, haga clic en ¥  y después desactive el
perfilado de datos. Esto cargará también todos los datos existentes de fuentes de datos
cuando agregue los datos. Las tablas se asociarán automáticamente en los nombres de
campos comunes. Los campos de fecha y hora no se crearán.

7. Haga clic en Cargar datos cuando haya terminado de preparar los datos. Si se detectaran problemas
serios, debe resolverlos en el Gestor de datos antes de poder cargar datos en la app.

Eliminar un archivo cargado


Cuando elimina una tabla basada en un archivo adjunto en el gestor de datos, la tabla se elimina del modelo de
datos, pero el archivo de datos adjunto permanece en la app. Puede eliminar el archivo de datos de la app
permanentemente si lo desea.

Haga lo siguiente:

1. Abra una app.


2. Abra el Gestor de datos y después haga clic en ú .
3. Haga clic en à Archivos adjuntos.
4. Elimine el archivo correspondiente.

El archivo de datos se ha eliminado ahora de forma permanente de la app.

Si elimina un archivo adjunto que esté en uso en la app, no podrá cargar la app hasta haber
eliminado las referencias al archivo en el Gestor de datos o en el script de carga. Puede editar los
scripts de carga en el Editor de carga de datos.

Cargar datos desde un archivo adjunto


Un archivo que cargue para una app se adjunta a dicha app y solo estará disponible para esa app.

No hay ninguna conexión con su archivo de datos original. Si actualiza el archivo original, necesita actualizar el
archivo que va adjunto a la app. Después ya puede cargar los datos actualizados en la app. Después de cargar
los datos en el Gestor de datos, haga clic en ô (Actualizar datos de la fuente) para ver los datos
actualizados en la vista de tabla.

No agregue una tabla en el Gestor de datos que ya se haya agregado como una tabla con
secuencias de script con el mismo nombre y las mismas columnas de datos en el Editor de carga
de datos.

Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 25


3   Administrar los datos de la app con el Gestor de datos

1. Abra una app.


2. Abra el Gestor de datos y después haga clic en ú .
3. Haga clic en à Archivos adjuntos.
4. Reemplace el archivo existente. El archivo actualizado debe tener el mismo nombre que el archivo
original. El contenido del archivo de datos se actualiza.
5. Haga clic en Añadir datos. Asegúrese de que los perfiles de datos estén habilitados haciendo clic en ¥ .
6. En la vista Asociaciones o la vista Tablas, haga clic en la tabla.
7. Haga clic en ô  para actualizar los datos.
8. Haga clic en Cargar datos para cargar los datos en la app.

Si ha hecho cambios en la estructura de campos del archivo de datos, es decir, ha eliminado o


renombrado campos, esto puede afectar al modelo de datos de su app, especialmente si esto
implica campos que se utilizan para asociar tablas.

Añadir datos manualmente en Qlik Sense


Entrada manual en Añadir datos le permite introducir datos en un editor y agregarlo como una tabla en el
Gestor de datos. La introducción manual de datos es útil si desea utilizar un conjunto limitado de datos de
otra fuente. Por ejemplo, si solo desea una selección de filas de una hoja de cálculo de Excel o de una tabla de
una página web para cargarla como una tabla en el Gestor de datos, podría copiar y pegar los datos
seleccionados en Entrada manual y después agregarlo como una tabla en el Gestor de datos. También es útil
si tiene una cantidad pequeña de datos que pueden ser más rápidos de agregar manualmente que
importándolos desde otra fuente de datos.

Para añadir datos manualmente, abra Añadir datos, seleccione Entrada manual, introduzca sus datos en la
tabla y luego agregue la tabla al Gestor de datos. El editor de tablas comienza con una fila y dos columnas,
pero a medida que añade datos a la tabla, las filas y columnas adicionales se agregan automáticamente a la
tabla.

Entrada manual no se guarda automáticamente a medida que se introducen los datos. Los datos
introducidos pueden perderse si la pantalla se actualiza, si la sesión expira o si la conexión se pierde
antes de que los datos se agreguen al Gestor de datos.

Además de escribir datos, puede copiarlos y pegarlos desde otras fuentes. Entrada manual conserva las
columnas y filas de datos copiadas de las tablas de Excel.

Internet Explorer 11 no admite copiar y pegar en la Entrada manual.

Gestión de datos - Qlik Sense, June 2019 26


3   Administrar los datos de la app con el Gestor de datos

Hay una serie de métodos abreviados de teclado que puede utilizar para trabajar con mayor eficacia y facilidad
en la Entrada manual. El comportamiento de los accesos directos varía dependiendo de si está seleccionando
celdas, filas o columnas o si está editando celdas en la tabla. La tabla siguiente contiene los accesos directos de
selección:

Métodos abreviados de teclado para seleccionar


Acceso
Descripción
rápido

Teclas de Navega entre la selección de celdas


flecha

Pestaña Mueve la selección de celda a la derecha. Si no existe una celda a la derecha, se mueve a la
primera celda de la fila siguiente.

Mayús+Tab Mueve la selección de celda a la izquierda. Si no existe una celda a la izquierda, se mueve a la
primera celda de la fila anterior.

Intro Cambia al modo de edición

Eliminar Elimina la selección actual

La tabla siguiente contiene los accesos directos de edición:

Métodos abreviados de teclado para editar


Acceso rápido Descripción

Teclas de flecha Mueve los cursores en la celda.

Pestaña Confirma la edición y se mueve a la siguiente celda a la derecha

Mayús+Tab Confirma la edición y se mueve a la celda anterior a la izquierda

Intro Confirma la edición y se mueve a la siguiente celda inferior

Mayús+Intro Confirma la edición y se mueve a la celda anterior superior

Esc Cancela la edición y cambia al modo de selección

Las tablas creadas con la Entrada manual se pueden editar posteriormente para añadir o eliminar contenido.
Para más información, vea Actualizar una tabla desde la fuente de datos (page 53).

Añadir datos manualmente


Haga lo siguiente:

1. Abra una app.


2. Abra el Gestor de datos y después haga clic en ú .
También puede hacer clic en Añadir datos en el menú ¨ .
3. En En app, haga clic en Entrada manual.
4. Escriba un nombre para la tabla.
5. En el editor de tablas, introduzca sus datos.

Gestión de datos - Qlik Sense, June 2019 27


3   Administrar los datos de la app con el Gestor de datos

Haga doble clic en una celda para comenzar a introducir datos en la celda.
Mientras edita una celda, al hacer clic en cualquier otra celda de la tabla, se confirma su edición y se
selecciona la otra celda.
6. Cuando sus datos estén completos, haga clic en Añadir datos.

La tabla se añade al Gestor de datos.

Seleccionar datos de campos


Puede seleccionar qué tablas y campos utilizar cuando añade datos, o cuando edita una tabla. Algunas fuentes
de datos, como un archivo CSV, contienen una sola tabla, mientras que otras fuentes de datos, como las bases
de datos u hojas de cálculo de Microsoft Excel, pueden contener varias tablas.

Si una tabla contiene una fila de cabecera, los nombres de campo por lo general se detectan automáticamente,
pero puede que tenga que modificar el parámetro Nombres de campo en algunos casos. Puede que también
necesite variar algunas otras opciones de tabla, por ejemplo el Tamaño de cabecera o el Juego de
caracteres para que los datos se interpreten correctamente. Las opciones de tabla son diferentes según los
distintos tipos de fuentes de datos.

Seleccionar datos de una base de datos


Los pasos para seleccionar datos de una base de datos dependen de la forma en que se conecte a la base de
datos. Puede conectar con un driver ODBC como fuente DSN o puede conectar directamente mediante un
conector Qlik Database que forme parte del paquete de conectores Qlik ODBC Connector Package instalado
junto con Qlik Sense.

Para más información, vea ODBC (page 202).

Si añade datos de una base de datos, la fuente de datos puede contener varias tablas.

Haga lo siguiente:

1. Seleccione una Base de datos de la lista desplegable.


Algunos diálogos de selección no tienen una lista desplegable Base de datos porque se introduce el
nombre de la base de datos cuando se configura la conexión.
2. Seleccione el Propietario de la base de datos.
La lista de Tablas se puebla de vistas y tablas disponibles en la base de datos seleccionada. Algunas
bases de datos no requieren que se especifiquen los propietarios en el proceso de selección de datos.
3. Seleccione una tabla.
4. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar.
Puede seleccionar todos los campos de la tabla marcando la casilla situada junto al nombre de tabla.

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

Gestión de datos - Qlik Sense, June 2019 28


3   Administrar los datos de la app con el Gestor de datos

5. Seleccione tablas adicionales si desea añadir datos de las mismas.


6. Cuando haya terminado con la selección de datos, haga clic en Añadir datos para continuar con la
creación de perfiles de datos y ver recomendaciones para las relaciones de la tabla.
Si desea cargar los datos directamente en su app, haga clic en ¥ junto a Añadir datos y después
desactive el perfilado de datos. Esto cargará los datos seleccionados tal cual están, saltándose el paso de
perfilado de datos y ya puede comenzar a crear visualizaciones. Las tablas se asociarán empleando las
asociaciones naturales, esto es, mediante sus campos de idéntico nombre.

Seleccionar datos desde una hoja de cálculo de Microsoft Excel


Cuando añade datos desde una hoja de cálculo de Microsoft Excel, el archivo puede contener varias hojas. Cada
hoja se carga como una tabla aparte. Una excepción es si la hoja tiene la misma estructura de
campos/columnas que otra hoja o tabla cargada, en cuyo caso las tablas se concatenan.

Haga lo siguiente:

1. Asegúrese de tener los parámetros adecuados para la hoja:


Configuración para ayudarlo a interpretar los datos de la tabla correctamente
Elemento
Descripción
de IU

Nombres Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de


de campo campo. Normalmente, en una hoja de cálculo de Excel, la primera fila contiene los
nombres de campo incluidos. Si selecciona Sin nombres de campo, los campos se
denominarán A,B,C...

Tamaño Defina el número de filas que se deben omitir como cabecera de tabla, por lo general
de filas que contengan información general que no esté en un formato de columna.
cabecera

Ejemplo
La hoja de cálculo presentará el siguiente aspecto:
Hoja de cálculo
Equipo: AEJ12B - -

Fecha: 2015-10-05 09 - -

Fecha-hora Orden Operador Resultado

2015-10-05 09:22 00122344 A 52

2015-10-05 10:31 00153534 A 67

2015-10-05 13:46 00747899 B 86

En este caso probablemente desee ignorar las dos primeras líneas y cargar una tabla con los campos
Timestamp, Order, Operator y Yield. Para lograr esto, utilice estos parámetros:

Gestión de datos - Qlik Sense, June 2019 29


3   Administrar los datos de la app con el Gestor de datos

Parámetros para ignorar las dos primeras líneas y cargar los campos
Elemento
Descripción
de IU

Tamaño 2
de Esto significa que las dos primeras líneas se consideran datos de cabecera y se ignoran
cabecera cuando se carga el archivo. En este caso, las dos líneas que comienzan con Machine: y
Date: se ignoran, ya que no son parte de los datos de la tabla.

Nombres Nombres de campo incluidos


de campo Esto significa que la primera línea que se lee se utiliza como nombres de campo para las
respectivas columnas. En este caso, la primera línea que se leerá es la tercera, porque las
dos primeras líneas son datos de cabecera.

2. Seleccione la primera hoja de la que seleccionar datos. Puede seleccionar todos los campos de una hoja
marcando la casilla situada junto al nombre de hoja.
3. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar.

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

4. Cuando haya terminado con la selección de datos, haga clic en Añadir datos para continuar con la
creación de perfiles de datos y ver recomendaciones para las relaciones de la tabla.
Si desea cargar los datos directamente en su app, haga clic en ¥ junto a Añadir datos y después
desactive el perfilado de datos. Esto cargará los datos seleccionados tal cual están, saltándose el paso de
perfilado de datos y ya puede comenzar a crear visualizaciones. Las tablas se asociarán empleando las
asociaciones naturales, esto es, mediante sus campos de idéntico nombre.

Seleccionar datos de un archivo de tabla


Puede añadir datos de un número mayor de archivos de datos.

Haga lo siguiente:

1. Asegúrese de que el tipo de archivo adecuado esté seleccionado en Formato de archivo.


2. Asegúrese de tener los parámetros adecuados para el archivo. Los parámetros de archivo son diferentes
según los distintos tipos de archivo.
3. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar. También puede seleccionar todos los campos de un archivo marcando la casilla situada junto al
nombre de hoja.

Gestión de datos - Qlik Sense, June 2019 30


3   Administrar los datos de la app con el Gestor de datos

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

Cuando haya terminado con la selección de datos, haga clic en Añadir datos para continuar con la
creación de perfiles de datos y ver recomendaciones para las relaciones de la tabla.

Si desea cargar los datos directamente en su app, haga clic en ¥ junto a Añadir datos y
después desactive el perfilado de datos. Esto cargará los datos seleccionados tal cual están,
saltándose el paso de perfilado de datos y ya puede comenzar a crear visualizaciones. Las
tablas se asociarán empleando las asociaciones naturales, esto es, mediante sus campos de
idéntico nombre.

4.

Escoger los parámetros para tipos de archivos


Archivos de tabla delimitados
Estas configuraciones se validan para archivos de tabla delimitados que contienen una única tabla en la que
cada registro va separado por un salto de línea y cada campo se separa con un carácter delimitado, por
ejemplo, un archivo CSV.

Configuraciones de formatos de archivo


Configuraciones de formato de archivo para archivos de tabla delimitados
Elemento de IU Descripción

Formato de archivo para Elija Delimitado o Registro fijo.


archivos de tabla
delimitados Cuando haga una selección, el cuadro de diálogo de selección de datos se
adaptará al formato de archivo que haya seleccionado.

Nombres de campo Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres
de campo.

Delimiter Escoja el carácter Delimitador que se utilizará en su archivo de tabla.

Entrecomillado Especifique cómo se tratarán las comillas:

Ninguno = las comillas no se aceptan

Estándar = entrecomillado estándar (las comillas se pueden usar como


caracteres iniciales y finales del valor de un campo)

MSQ = estilo de comillas modernas (que permite un contenido de múltiples líneas


en los campos)

Tamaño de cabecera El número de líneas que desee omitir como cabecera de tabla.

Gestión de datos - Qlik Sense, June 2019 31


3   Administrar los datos de la app con el Gestor de datos

Elemento de IU Descripción

Character set El juego de caracteres que se empleará en el archivo de tabla.

Comentario Los archivos de datos pueden contener comentarios entre registros, los cuales se
caracterizan por una línea inicial con uno o más caracteres especiales, por
ejemplo //.

Especifique uno o más caracteres que denotarán una línea de comentario. Qlik
Sense no carga líneas que comiencen con los caracteres aquí especificados.

Ignorar EOF Seleccione Ignorar EOF si sus datos contienen caracteres de final de archivo
como parte del valor de campo.

Archivos de tabla con registros de longitud fija


Los archivos de registros de longitud fija contienen una única tabla en la que cada registro (cada fila de datos)
contiene varias columnas con un tamaño fijo de campo, normalmente rodeados de caracteres tipo espacios o
tabuladores.

Configurar posiciones de salto de campo


Podemos configurar posiciones de salto de campo de dos maneras:

l Introduzca manualmente las posiciones de salto de campo separadas por comas en Posiciones de
salto de campo. Cada posición marca el inicio de un campo.

Example: 1,12,24

l Habilite Saltos de campo para editar las posiciones de salto de campo interactivamente en la vista
previa de los datos de campo. Las Posiciones de salto de campo se actualizan con las posiciones
seleccionadas. Podemos:
l Hacer clic en la vista previa de datos de campo para insertar un salto de campo.
l Hacer clic en un salto de campo para eliminarla.
l Arrastrar un salto de campo para moverlo.

Configuraciones de formatos de archivo


Configuración de formato de archivo para archivos de datos de registro fijo
Elemento de IU Descripción

Nombres de campo Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de
campo.

Tamaño de cabecera Establezca el Tamaño de cabecera en el número de líneas que desee omitir como
cabecera de tabla.

Character set Establezca el juego de caracteres que se empleará en el archivo de tabla.

Tamaño de pestaña Defina el número de espacios que un carácter de tabulador representa en el


archivo de tabla.

Gestión de datos - Qlik Sense, June 2019 32


3   Administrar los datos de la app con el Gestor de datos

Elemento de IU Descripción

Tamaño de línea de Defina el número de líneas que ocupa un registro en el archivo de tabla. Por defecto
registro es 1.

Archivos HTML.
Los archivos HTML pueden contener varias tablas. Qlik Sense interpreta todos los elementos con una etiqueta
<TABLE> como una tabla.

Configuraciones de formatos de archivo


Configuración de formato de archivo para archivos HTML
Elemento de IU Descripción

Nombres de Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de


campo campo.

Character set Especifique el juego de caracteres empleado en el archivo de tabla.

Archivos XML.
Puede cargar datos que estén almacenados en formato XML.

No hay configuraciones específicas de formato de archivo para los archivos XML.

Archivos QVD.
Puede cargar datos que estén almacenados en formato QVD. QVD es un formato nativo de Qlik y solo pueden
leerlo y escribirlo Qlik Sense o QlikView. El formato de archivo está optimizado para mejorar la velocidad de
lectura de datos desde un script Qlik Sense, pero es al mismo tiempo muy compacto.

No hay configuraciones específicas de formato de archivo para los archivos QVD.

Archivos QVX.
Puede cargar datos almacenados en formato Qlik data eXchange (QVX). Los archivos QVX se crean mediante
conectores personalizados desarrollados con Qlik QVX SDK.

No hay configuraciones específicas de formato de archivo para los archivos QVX.

Archivos KML.
Puede cargar archivos de mapas que estén almacenados en formato KML, para usarlos en visualizaciones de
mapas.

No hay configuraciones específicas de formato de archivo para los archivos KML.

Volver al paso anterior (Añadir datos)


Podemos volver al paso anterior cuando añadimos datos.

Haga lo siguiente:

l Haga clic en la flecha hacia atrás para volver al paso anterior de Añadir datos.

Gestión de datos - Qlik Sense, June 2019 33


3   Administrar los datos de la app con el Gestor de datos

Filtrar datos de archivos


Puede crear condiciones de filtrado cuando carga datos desde archivos. Esto le permite seleccionar un
subconjunto de datos para cargar. Esto puede resultar útil cuando desea reducir la cantidad de datos cargados
o solo usar datos específicos, como únicamente las ventas por encima de 40.000 dólares.

La primera vez que agregue datos de un archivo en el paso Añadir datos, puede aplicar condiciones de filtrado
haciendo clic en Filtros.

Posteriormente, puede cambiar las condiciones haciendo clic en su tabla en el Gestor de datos y luego
haciendo clic en Editar esta tabla. Haga clic en Seleccionar datos y después clic en Filtros.

Las condiciones disponibles para los filtros son:

l =
l >
l <
l >=
l <=

Tenga en cuenta lo siguiente al filtrar datos. Se proporcionan ejemplos a continuación.

l Puede aplicar condiciones de filtro a números, fechas o texto.


l Los caracteres comodín no son compatibles.
l Puede aplicar varias condiciones. No obstante, las condiciones conflictivas en el mismo campo pueden
ocasionar que no se devuelvan datos.
l Las condiciones se aplican alfabéticamente a los datos de texto. Las condiciones son sensibles a
mayúsculas y minúsculas.
l Puede usar más de una letra para los datos de texto. Por ejemplo, >az devolverá la palabra taza, igual
que >=ta. Tenga en cuenta que >t también devolverá taza.
l Cuando utiliza más de una condición =, todas deben evaluarse y devolver valores verdaderos. No
obstante, si utiliza más de una condición = en el mismo campo, devolverá todos los valores que se
evalúen como verdaderos.
l Las condiciones < y >, cuando se combinan, deben devolver todas valores verdaderos. Si estas
condiciones se combinan con =, todas las condiciones deben evaluarse como verdaderas.
l Las condiciones <= y >=, cuando se combinan, deben devolver todas valores verdaderos. Si estas
condiciones se combinan con =, todas las condiciones deben ser evaluadas como verdaderas.
l Los filtros en los campos de fecha de archivos QVD no son compatibles.

Ejemplos
Estos ejemplos utilizan los siguientes valores de un solo campo (una columna en una tabla): taza, tenedor y
cuchillo.

Gestión de datos - Qlik Sense, June 2019 34


3   Administrar los datos de la app con el Gestor de datos

l Condiciones:
l =taza
l =tenedor
l =cuchillo
l Devuelve: taza, tenedor , cuchillo
l La condición igual devuelve todos los valores que son verdaderos.

l Condiciones:
l >b
l <d
l Devuelve: taza
l La letra c es a la vez mayor que b y menor que d.

l Condiciones:
l <b
l >d
l Devuelve: cero valores
l No puede haber valores que sean a la vez b y mayor que d.

l Condiciones:
l =tenedor
l >g
l Devuelve: cero valores
l No puede haber valores que sean a la vez tenedor y mayor que g.

Filtrar datos desde conectores de bases de datos

Filtrar datos no está disponible actualmente para todos los conectores o Qlik DataMarket.

Introduzca una expresión de filtro de datos seleccionando Filtrar datos en el paso Seleccione los datos para
cargar. Si selecciona Filtrar datos, se abre un cuadro de texto donde se introduce una expresión de filtro. Por
ejemplo:

Ventas >= 40000

Filtrar datos selecciona entre campos individuales, por ejemplo Ventas. Funciona como una cáusula SQL
WHERE. La mayoría de los operadores y palabras clave utilizadas en cáusulas WHERE pueden usarse con Filtrar
datos. Ejemplos de operadores válidos son:

l =
l >
l >=
l <

Gestión de datos - Qlik Sense, June 2019 35


3   Administrar los datos de la app con el Gestor de datos

l <=
l IN
l BETWEEN
l LIKE
l IS NULL
l IS NOT NULL

Qlik Sense crea una cáusula WHERE en el script de carga de datos desde la expresión introducida en Filtrar
datos.

El operador AND se puede usar para combinar operadores, como cuando desea filtrar por más de un campo.
Por ejemplo:

Sales <= 30000 AND RegionID = 45

El operador OR se puede usar para filtrar datos que coincidan con cualquiera de las condiciones. Por ejemplo:

Name = 'Smith' OR Name = 'Jones'

Puede obtener los mismos resultados del operador IN. El operador IN es un método abreviado para usar
múltiples condiciones OR. Por ejemplo:

Name IN ('Smith', 'Jones')

Añadir datos de Qlik DataMarket


Qlik DataMarket ofrece una extensa recopilación de datos actualizados y listos para su uso, procedentes de
fuentes externas y accesibles directamente desde Qlik Sense. Qlik DataMarket ofrece datos históricos y
actualizados de condiciones meteorológicas y datos demográficos, tipos de cambio de divisa, así como
indicadores empresariales, económicos y otros datos sociales.

Esta funcionalidad no está disponible en Kubernetes.

Qlik DataMarket también ofrece conjuntos de datos de la base de datos Eurostat, incluyendo Database by
themes, Tables by themes, Tables on EU policy y Cross cutting topics.

Cuando añadimos datos de Qlik DataMarket, seleccionamos categorías y a continuación filtramos los campos
de datos disponibles en dichas categorías. Las categorías de DataMarket contienen grandes cantidades de datos,
y filtrarlos permite tomar subconjuntos de los datos y reducir la cantidad de datos cargados.

Algunos datos de Qlik DataMarket están disponibles de forma gratuita. Los paquetes de datos marcados como
Premium están disponibles mediante una tarifa de suscripción.

Antes de poder usar los datos de Qlik DataMarket, debemos aceptar los términos y condiciones para su uso.
También, si hemos comprado una licencia para paquetes de datos premium, debemos introducir nuestras
credenciales de acceso para poder utilizar los datos en dichos paquetes. Una vez aplicadas las credenciales de
acceso, los datos premium se marcan como Con licencia.

Gestión de datos - Qlik Sense, June 2019 36


3   Administrar los datos de la app con el Gestor de datos

Si acepta los términos y condiciones pero no introduce una licencia para cualquiera de los paquetes de datos
premium, los paquetes de datos premium llevan junto a ellos un botón Comprar que le permite adquirir una
licencia. El botón Comprar reemplaza a la indicación Premium.

No es necesario aceptar los términos y condiciones de Qlik DataMarket cuando usamos Qlik Sense
Desktop. Tampoco se requieren credenciales de acceso porque los paquetes de datos premium no
están disponibles en Qlik Sense Desktop.

Haga lo siguiente:

1. Abra su app.
2. Abra el Gestor de datos y después haga clic en ú . También puede hacer clic en Añadir datos en el
menú ¨  .
3. Haga clic en Qlik DataMarket para mostrar los paquetes Qlik DataMarket.

La interfaz de usuario de DataMarket se puede bloquear mediante extensiones de


navegador, como Privacy Badger, que bloquea los anuncios y mejora la privacidad. Esto
ocurre si la extensión confunde las comunicaciones de DataMarket para seguimiento de los
usuarios con un tercero. Si se encuentra con esto, puede acceder a DataMarket excluyendo
su sitio Qlik Sense de la lista de sitios bloqueados en la extensión del navegador que está
bloqueando DataMarket.

4. Seleccione un paquete de datos.


Seleccione un paquete de datos de la lista (por ejemplo, Básico gratuito o Informes financieros), o
puede buscar tipos específicos de datos. Para buscar en Qlik DataMarket, seleccione Buscar en
DataMarket en la parte superior de la lista de paquetes de datos e introduzca un término de búsqueda
en el recuadro de búsqueda del paso Seleccionar una base de datos.
5. Seleccione un conjunto de datos en el paso Seleccionar un conjunto de datos.
Dependiendo del paquete de DataMarket que seleccione, puede que tenga que seleccionar varias
subcategorías dentro del paquete hasta llegar a los conjuntos de datos individuales que contienen los
datos que le interesan. Los conjuntos de datos se distinguen por el icono ] situado junto a la
descripción del conjunto de datos. Hacer clic en el icono ] muestra los metadatos del conjunto de
datos.
Seleccionar el conjunto de datos crea una conexión a ese conjunto de datos específico.
6. Seleccione al menos un filtro de cada dimensión, medida y período de tiempo en el paso Seleccione los
datos para cargar.
El panel de la izquierda enumera las dimensiones, medidas y períodos de tiempo. Si hace clic en una
dimensión, medida o período de tiempo en el panel de la izquierda, los valores de dicha dimensión,
medida o período de tiempo se muestran en el panel de la derecha.
Hay un indicador de tamaño de carga en la parte inferior de la columna izquierda que indica
aproximadamente cuántas celdas se cargarán con los campos actualmente seleccionados. El indicador

Gestión de datos - Qlik Sense, June 2019 37


3   Administrar los datos de la app con el Gestor de datos

es de color verde cuando el número es pequeño y se vuelve amarillo cuando el número asciende a un
tamaño que podría afectar notablemente al tiempo de carga. El indicador se vuelve de color rojo
cuando la cantidad de datos es tan grande que podría no cargarse bien.
7. Haga clic en Añadir datos para abrir los datos en la vista Asociaciones del gestor de datos. Esto le
permite continuar añadiendo fuentes de datos, transformar los datos y asociar las tablas en el Gestor
de datos.
El perfilado de datos está activo por defecto al hacer clic en Añadir datos. El perfilado de datos hace lo
siguiente:
l Recomienda asociaciones de datos.
l Califica automáticamente los campos comunes entre tablas. Esto agrega un prefijo único basado
en el nombre de la tabla.
l Asigna los campos de fecha y hora a autoCalendar.
Las tablas no se asocian automáticamente en los nombres de campos comunes. Puede asociar tablas en
la vista Asociaciones.

Si desea cargar los datos directamente en su app, haga clic en ¥  y después desactive el
perfilado de datos. Esto cargará también todos los datos existentes de fuentes de datos
cuando agregue los datos. Las tablas se asociarán automáticamente en los nombres de
campos comunes. Los campos de fecha y hora no se crearán.

8. Haga clic en Cargar datos cuando haya terminado de preparar los datos. Si se detectaran problemas
serios, debe resolverlos en el Gestor de datos antes de poder cargar datos en la app.

Seleccionar dimensiones, medidas y períodos de tiempo en Qlik DataMarket


Los conjuntos de datos de Qlik DataMarket contienen dimensiones, medidas y períodos de tiempo. Las
dimensiones definen el contexto de los datos, como por ej. país, grupo de edad o género. Las medidas contienen
datos numéricos que se relacionan con el contexto de las dimensiones. Los períodos de tiempo especifican los
años u otros períodos para los que deben mostrarse las medidas.

Esta funcionalidad no está disponible en Kubernetes.

Los conjuntos de datos contienen al menos una dimensión y una medida, y todos ellos tienen dimensiones de
tiempo. Antes de poder añadir datos a una app, debe seleccionar al menos una dimensión y una medida y
establecer el período de tiempo. Cuando seleccione dimensiones, debe incluir dimensiones que contengan datos.
Cuando los datos están estructurados jerárquicamente, es posible que una rama padre no contenga datos.

Algunas dimensiones contienen múltiples representaciones de los datos. Por ejemplo, las ubicaciones
geográficas designadas por el nombre de país también contienen códigos ISO (Organización Internacional de
normalización) para los países. Las monedas contienen los nombres habituales, como Pound sterling y Euro, así
como su código ISO 4217 GBP y EUR. Los valores adicionales para las dimensiones no se pueden seleccionar por
separado. Se muestran en la descripción de la dimensión.

Datos seleccionados para cargar la vista con los valores extra mostrados en la descripción de la dimensión.

Gestión de datos - Qlik Sense, June 2019 38


3   Administrar los datos de la app con el Gestor de datos

Los valores adicionales se cargan como campos aparte.

En algunos conjuntos de datos, no es necesario seleccionar una medida porque el conjunto de datos contiene
sólo una medida. Las selecciones de medidas se muestran sólo cuando hay más de una medida entre las que
elegir. Por ejemplo, el conjunto de datos US per capita personal income by state muestra solo la dimensión
geográfica y el período de tiempo porque solo hay una medida en el conjunto de datos: ingreso personal per
cápita.

También hay conjuntos de datos que no requieren selección de las dimensiones. Por ejemplo, los conjuntos de
datos US federal interest rate y US consumer price index for urban consumers solo requieren que
seleccione el período de tiempo porque solo hay una dimensión y una medida en esos conjuntos de datos. En el
primer caso, la medida es el tipo de interés federal y la dimensión es los Estados Unidos. En el segundo caso, la
medida es el índice de precios al consumo, y la dimensión es los consumidores urbanos de Estados Unidos.

Los conjuntos de datos pueden contener sólo dimensiones que no tienen datos adjuntos para las medidas. Un
conjunto de datos puede contener, por ejemplo, sólo una lista de los principales ejecutivos de la empresa. En
tales casos, la dimensión se preselecciona porque no hay selecciones que hacer dentro de la dimensión.

Gestión de datos - Qlik Sense, June 2019 39


3   Administrar los datos de la app con el Gestor de datos

Seleccionar datos jerárquicos de Qlik DataMarket

Muchos conjuntos de datos en Qlik DataMarket contienen dimensiones y medidas que están estructuradas
jerárquicamente. Los conjuntos de datos de DataMarket que están estructurados jerárquicamente contienen
jerarquías de dos y tres niveles. Cómo hacer selecciones en dichas jerarquías depende de los datos de cada nivel.

Esta funcionalidad no está disponible en Kubernetes.

Seleccionar ramas padre e hijo


En algunas jerarquías, se pueden hacer selecciones en todos y cada uno de los niveles. Por ejemplo, el conjunto
de datos Selected development indicators contiene la dimensión Geographical area con tres niveles.

Los indicadores de desarrollo seleccionados contienen la dimensión Área geográfica con tres niveles.

Una selección de World, Region o Country es válida por sí misma. Cualquier selección que incluya el valor más
alto carga todos los datos para las regiones y países incluso si también se han seleccionado regiones y países
específicos. Pero si una región se ha seleccionado por sí misma, entonces sólo se carga esa región del mundo.

Si selecciona ambos, World y North America, los datos del mundo se muestran aparte de los datos de la región
North America.

Gestión de datos - Qlik Sense, June 2019 40


3   Administrar los datos de la app con el Gestor de datos

Si selecciona Canada desde Country, entonces obtendrá datos aparte del mundo, de la región North America y
del país Canada.

Si selecciona Canada desde Country pero no selecciona North America, entonces los datos agregados de
North America no se cargan. Solo los datos de Canada se cargan para la región North America.

Seleccionar ramas padre que no contienen datos


En algunos conjuntos de datos, la rama padre de una jerarquía no contiene ningún dato. Las ramas padre sin
datos se indican mediante casillas de verificación con líneas discontinuas, como en el conjunto de datos US
social characteristics (by state) .

Las características sociales de EEUU (por estado) contienen tres ramas principales sin datos; Ascendencia, estado de
discapacidad de la población civil no institucionalizada y nivel educativo.

Cuando se selecciona el campo padre, todos los hijos de la rama se seleccionan también automáticamente.
Para seleccionar algunos, en lugar de seleccionar todos los hijos de la rama, puede, o bien deseleccionar
archivos de forma individual desde la selección automática del padre, o seleccionar campos de forma individual
sin seleccionar el campo padre.

Seleccionar datos agregados de Qlik DataMarket


Algunos conjuntos de datos de Qlik DataMarket contienen dimensiones que incluyen un valor del campo
agregado. Estas dimensiones representan jerarquías y contienen más de un campo, que representan los niveles
de esa jerarquía. Puede que los campos incluidos en la jerarquía tengan valores en blanco. Los números

Gestión de datos - Qlik Sense, June 2019 41


3   Administrar los datos de la app con el Gestor de datos

asociados con esos valores en blanco son agregados de los números asociados con los demás valores de ese
campo.

Esta funcionalidad no está disponible en Kubernetes.

Por ejemplo, el conjunto de datos World population by country contiene una dimensión Sex. Tiene los
valores del campo del subconjunto Female y Male. Cuando se carga Género en Qlik Sense, contiene tres
valores: Female, Male y un valor en blanco para el valor del campo agregado.

Gráfico de barras con la dimensión Género, que muestra la población total masculina y femenina de Argentina como dos
barras aparte en un gráfico de barras, con una barra sin nombre para el total agregado.

En el ejemplo que se muestra en la imagen, el valor del campo agregado contiene el total de Female y Male.

Gestión de datos - Qlik Sense, June 2019 42


3   Administrar los datos de la app con el Gestor de datos

El campo del valor en blanco se incluye siempre que se incluyen todos los valores del campo del subconjunto de
una dimensión. Los totales asociados a los valores de campos agregados están presentes en los datos, por lo
que podrían causar un recuento doble si se incluyen al calcular agregados de los datos.

Dependiendo de las visualizaciones que utilice, puede excluir los valores de campos agregados. Por ejemplo:

l Defina el valor en blanco como nulo por medio del panel de perfiles de datos Definir nulos en Gestor
de datos y borre Incluir valores nulos en la sección Dimensión de Propiedades para excluir el valor
nulo de la dimensión.
l Utilice una expresión para limitar los valores incluidos en la dimensión y, a continuación, borre Incluir
valores nulos en la sección Dimensión de Propiedades. Por ejemplo, en la dimensión Género, se
puede utilizar la expresión =if(match(Sex,'Female','Male'),Sex) para excluir el valor del campo agregado.
l Utlice expresiones de Análisis de conjuntos para excluir de una medida los números agregados del valor
en blanco.

Cuando trabaje con conjuntos de datos como World population by country, que contienen
múltiples campos con datos agregados, asegúrese de que las tablas con esos campos agregados no
estén directamente asociadas. Si se asocian directamente, es probable que creen una referencia
circular.

Buscar en Qlik DataMarket


La herramienta de búsqueda de Qlik DataMarket le ayuda a encontrar los datos que necesita mediante la
búsqueda de términos o frases para no tener que navegar por los paquetes y conjuntos de datos. El término o
frase introducido se busca en los nombres y descripciones de paquetes DataMarket y en los valores dentro de los
conjuntos de datos.

Esta funcionalidad no está disponible en Kubernetes.

Por ejemplo, si busca el término europa, obtiene una primera lista de todos los conjuntos de datos que
contienen el término Europa en el título, seguido de los conjuntos de datos que contienen datos etiquetados con
el término. En el caso del término europa, uno de los conjuntos de datos encontrados es Selected
development indicators, que contiene el término en su dimensión Geographical area - Europe & Central
Asia.

DataMarket busca el término o frase literal que introducimos, y también busca en términos y sinónimos
relacionados. Un término introducido en singular también se busca en su forma plural. Por ejemplo, los
términos currency y index tienen las formas plurales --currencies y indices-- que también se buscan al mismo
tiempo que sus formas singulares.

La herramienta de búsqueda también busca resultados en función de la raíz léxica de los términos. Por ejemplo,
si busca el término production, la forma raíz de la palabra --product-- también se busca.

Gestión de datos - Qlik Sense, June 2019 43


3   Administrar los datos de la app con el Gestor de datos

DataMarket no busca términos parciales. Por ejemplo, no encuentra la cadena "prod" aunque
forme parte de los términos product y production, que son términos que el motor de búsqueda sí
encuentra en frases como Gross Domestic Product.

Qlik DataMarket también contiene un índice de sinónimos, por lo que se puede encontrar una amplia gama de
datos sin necesidad de utilizar el término exacto empleado en el nombre o la descripción de la recopilación de
datos o en los campos de datos. Por ejemplo, los conjuntos de datos que usan la dimensión etiquetada como
Sex también se encuentran con el término gender . El servicio de búsqueda de DataMarket tiene más de 200
conjuntos de sinónimos. Algunos sinónimos que incluye son:

l ingresos, ganancias
l GBP, libras
l sanidad, salud, cuidado de la salud
l mano de obra laboral, trabajo
l retribución, salario, sueldo, ganancias

Los resultados de la búsqueda se muestran de mayor a menor relevancia. La relevancia viene determinada por
el lugar en que se encuentre el término de búsqueda. Los términos que se encuentran en nombres o
descripciones de los conjuntos de datos tienen una mayor relevancia que los términos que se encuentran dentro
de los valores del conjunto de datos.

Cuando se introducen varios términos de búsqueda, los resultados no incluyen necesariamente todos los
términos. Si solo se encuentra uno de los términos, la entrada que contiene el término se devuelve como uno de
los resultados de búsqueda. Sin embargo, las entradas que contienen más de los términos de búsqueda
introducidos tienen más relevancia.

Solo se muestran los 50 mejores resultados de una búsqueda.

Para restringir las búsquedas, puede excluir términos de la búsqueda colocando un guion antes de los términos
cuando estos se introducen en la cadena de búsqueda. Por ejemplo, puede buscar "US" pero excluir
unemployment colocando un guión antes del término de búsqueda "-unemployment."

Hacer asociaciones en Qlik DataMarket

Esta funcionalidad no está disponible en Kubernetes.

Cuando los datos se cargan desde un conjunto de datos de Qlik DataMarket, se asignan a varias tablas
individuales. Estas tablas se asocian mediante los campos clave generados. Las medidas y los períodos de
tiempo del conjunto de datos se consolidan en una tabla a la que se asigna el nombre del conjunto de datos. Los
campos de dimensión se asignan a las tablas individuales. Por ejemplo, el conjunto de datos 3x3 currency
exchange rates se carga como tres tablas:

Gestión de datos - Qlik Sense, June 2019 44


3   Administrar los datos de la app con el Gestor de datos

Algunas dimensiones ofrecen campos adicionales cuando se cargan. Los campos extra proporcionan
representaciones adicionales de las dimensiones. En el conjunto de datos 3x3 currency exchange rates, las
monedas también se enumeran por su representación iso4217. Por ejemplo:

Monedas
Moneda base Euro

Moneda base iso4217 EUR

Moneda de cotización Dólar US

Moneda de cotización iso4217 USD

Los conjuntos de datos con datos de población por país y región ofrecen representaciones de dimensión
adicionales para los nombres de las regiones, como los códigos ISO 3166.

Asociar varias tablas de un conjunto de datos


Todas las tablas de un mismo conjunto de datos deberían asociarse a través de la tabla de medidas. Cuando se
carga un conjunto de datos desde Añadir datos, las asociaciones se realizan de forma automática a partir de
los campos clave generados. El siguiente modelo de datos muestra el conjunto de datos US population by
state, race, sex and age. Las tablas de dimensiones (Age, Sex, Location y Race) se asocian a través de la
tabla de medidas, que tiene el nombre del conjunto de datos.

Gestión de datos - Qlik Sense, June 2019 45


3   Administrar los datos de la app con el Gestor de datos

Estas asociaciones son necesarias para interpretar las relaciones entre las dimensiones y las medidas que son
importantes en las visualizaciones. Por ejemplo, si una empresa desea utilizar los datos de población de US para
comparar sus ventas de producto con los grupos de edad en varios estados de US, las dimensiones Age y
Location deben asociarse a través de la tabla de medidas para obtener el número de personas de cada grupo
en los distintos estados.

Cuando los conjuntos de datos tienen múltiples tablas de dimensiones, a menudo hay asociaciones adicionales
que se pueden hacer. Por ejemplo, los campos agregados generalmente tienen el mismo valor ("Total") eso
sugiere una posible asociación. Esas asociaciones no son útiles, sin embargo, y pueden ocasionar referencias
circulares.

La estructura de múltiples tablas aumenta la eficiencia de la carga de datos y puede mejorar las asociaciones de
datos.

Convertir conjuntos de datos de una sola tabla en múltiples tablas


Antes de Qlik Sense 3.0, los conjuntos de datos de DataMarket,se cargaban como tablas individuales. En Qlik
Sense 3.0, esas tablas previamente cargadas permanecen como tablas individuales, y cualquier visualización
que las utilicen continúan funcionando igual que antes. Puede convertir esas tablas individuales en múltiples
tablas, y las visualizaciones continuarán funcionando sin modificaciones. Al convertirlas, se obtiene la eficiencia
de tener múltiples tablas.

Haga lo siguiente:

1. Abra el Gestor de datos.


2. Elimine la tabla que contiene el conjunto de datos de DataMarket que desea convertir en múltiples tablas.
La tabla está marcada como Pendiente de eliminar.
3. Haga clic en ú  para añadir datos.
4. Seleccione Qlik DataMarket.
5. Seleccione el conjunto de datos correspondiente a la tabla que ha eliminado.
Cuando se abra la página Seleccione los datos para cargar, se muestra la selección que realizó
previamente. No cambie las selecciones a menos que también tenga previsto cambiar las visualizaciones
que utilizan el conjunto de datos. Si cambia las selecciones, las visualizaciones existentes que utilizan el
conjunto de datos ya no funcionarán.
6. Haga clic en ¥  junto al botón Añadir datos y después deshabilite el perfilado de datos.

Gestión de datos - Qlik Sense, June 2019 46


3   Administrar los datos de la app con el Gestor de datos

7. Haga clic en Añadir datos.


El conjunto de datos se carga en múltiples tablas y se elimina la tabla única.

Compruebe las visualizaciones que utilizan el conjunto de datos que convirtió en múltiples tablas. Deberían
funcionar tal como se diseñaron originariamente a menos que haya cambiado los datos seleccionados, ya sea
mediante la adición o eliminación de algunas de las selecciones realizadas cuando la tabla se cargó
previamente.

Integrar datos corporativos con datos de DataMarket


Puede integrar datos de Qlik DataMarket con sus datos de empresa para aportar un mayor contexto a los datos
y extraer mayor conocimiento de sus mercados.

Esta funcionalidad no está disponible en Kubernetes.

Los datos de DataMarket proceden de una amplia variedad de fuentes, por ello las asociaciones con sus datos
podrían no resultar evidentes de inmediato. Puede que se encuentre con que varias de las asociaciones deben
ser editadas en el paso previo. Por ejemplo, podría estimar valioso evaluar ciertas características de los países
en los que opera. Pero los campos de países de algunos conjuntos de datos de DataMarket podrían no tener
suficientes valores en común con sus datos corporativos para hacer que la asociación sea útil. Por eso es por lo
que debe evaluar siempre con cuidado las asociaciones entre sus datos y los datos de DataMarket.

Las imágenes a continuación demuestran cómo integrar datos corporativos y datos de DataMarket para crear
visualizaciones potentes de Qlik Sense.

Comparar ventas con el Producto Interior Bruto (GDP)


Cuando usted está haciendo negocios en un país o se plantea entrar en el mercado de un país, hay una serie de
indicadores que pueden ayudarle a determinar si el rendimiento de su empresa se está alineando tal como se
esperaba con el entorno demográfico y económico de ese país.

Los datos de la empresa en este ejemplo permiten agrupar los datos de ventas por país. Un gráfico de barras
que compara las ventas por país. Esto puede darle una idea de cómo se está comportando su empresa en todos
sus mercados.

Para ver qué tal lo está haciendo en cada país, se podrían comparar las ventas de su empresa con los datos del
país, lo que nos indica la fuerza de ese mercado. Por ejemplo, podría comparar las ventas en cada país con el
Producto Interior Bruto del país (GDP). O se podrían comparar las ventas con la demografía de su mercado
objetivo. Si el objetivo de su empresa son personas de 21 a 35 años, se puede ver cuántas personas de esa edad
tienen los países. O ver qué porcentaje de la población total está en ese rango de edad.

Qlik DataMarket contiene un conjunto de datos en el grupo Essentials Free llamado Select development
indicators que proporciona una serie de medidas económicas, incluidas tasas de crecimiento GDP,
alfabetización, usuarios de Internet, población total y GDP per capita in US dollars. Para asociar datos de países
desde Select development indicators, los datos corporativos deben tener un campo que coincida con el campo
Country del conjunto de datos DataMarket. Si los datos corporativos tienen muchos más países que Select
development indicators, la asociación no sería sólida y probablemente no sea útil. Si los datos corporativos
tienen menos países que Select development indicators, la asociación probablemente sea útil para una
comparación.

Gestión de datos - Qlik Sense, June 2019 47


3   Administrar los datos de la app con el Gestor de datos

Suponiendo que exista una buena asociación entre los campos de país de los datos corporativos y los datos de
DataMarket, puede agregar GDP per capita in US dollars al gráfico de barras de ventas para comparar las
ventas de cada país con el Producto Interior Bruto (PIB) (GDP en inglés).

Mostrar las ventas en euros


Para revisar los datos de ventas, una visualización habitual es el gráfico de KPI que muestra el total de ventas.
En este ejemplo el total de ventas es en dólares estadounidenses, porque así es como se registran los datos
corporativos de esta empresa. Con tantas ventas en países que utilizan el euro, sería bueno poder ver el total de
ventas en euros. Eso puede añadirse al KPI. En el grupo Essentials Free, DataMarket contiene 3x3 currency
exchange rates, las cuales se pueden usar para convertir dólares estadounidenses a euros.

Al seleccionar el campo Base currency en el conjunto de datos 3x3 currency exchange rates, seleccionaría solo
dólares estadounidenses porque esa es la moneda en la que se registran las ventas. En el conjunto de datos
corporativos utilizado en esta ilustración, hay un campo llamado Base currency que indica la moneda que usa
cada cliente. Sin embargo, contiene doce monedas diferentes, y como resultado, el Gestor de datos
recomienda no asociar los dos campos. No debería asociar esos campos porque las monedas en los datos
corporativos que no corresponden a dólares estadounidenses y euros pueden interferir con algunas
comparaciones entre dólares y euros. El modelo de datos presentará entonces el siguiente aspecto:

La Quote currency de 3x3 currency exchange rates debería ser Euro. La selección DateTime debería ser Most
recent porque solo desea la tasa de cambio actual, no los datos históricos, para la visualización KPI.

Gestión de datos - Qlik Sense, June 2019 48


3   Administrar los datos de la app con el Gestor de datos

Para obtener Euro Sales, simplemente multiplique Sum(Sales) por Exchange rate en el conjunto de datos 3x3
currency exchange rates.

Crear medidas alternativas para ventas


Con los datos de moneda de DataMarket, se puede añadir una mejora adicional al gráfico de barras de ventas.
El gráfico compara las ventas con el PIB per cápita (GDP) en dólares estadounidenses para cada país, pero se
pueden agregar medidas alternativas para las ventas y el GDP. Sum(Sales) se puede multiplicar por Exchange
rate en la tabla 3x3 currency exchange rates para mostrar las ventas en euros, tal como se hizo en el Sales KPI.
El GDP per cápita en dólares estadounidenses se puede multiplicar por Exchange rate también, y luego el
gráfico de barras compara las ventas con el PIB per cápita en euros.

Aquí es donde es importante que los campos Base currency no estén enlazados porque, como se indicó
anteriormente, el campo del conjunto de datos corporativos Base currency contiene doce monedas diferentes.
Cuando el cálculo del tipo de cambio se realiza en los países de forma individual, la moneda base de cada país
se utilizaría si las tablas estuvieran vinculadas. Pero los datos de la empresa no contienen ningún valor de
ventas en la mayoría de esas doce monedas. Contiene los valores de venta solo en dólares estadounidenses. Y la
Base currency del conjunto de datos DataMarket es solo dólares estadounidenses, por lo que para cualquier país
que tenga un valor de Base currency distinto al dólar estadounidense en los datos corporativos, Sales in euros
sería un valor nulo si las dos tablas estuvieran enlazadas.

3.12 Editar una tabla


Puede editar una tabla que se añadió a la app en la vista general del Gestor de datos, para renombrar la
tabla, asociar la tabla a otras tablas o hacer transformaciones en los campos.

Gestión de datos - Qlik Sense, June 2019 49


3   Administrar los datos de la app con el Gestor de datos

Para editar una tabla, seleccione la tabla en el Gestor de datos y haga clic en @ . El editor de tabla se
muestra, con una vista previa de los datos que hay en la tabla. Cada campo tiene un menú de campo con
opciones de transformación. El menú del campo se abre haciendo clic en Ô . Al seleccionar un campo se
muestra el panel de perfiles de datos, que contiene un resumen de los datos del campo, así como opciones de
transformación adicionales.

Si los datos contienen registros con idénticos datos en todos los campos que se cargan, estos vienen
representados por un único registro en la tabla de vista previa.

Renombrar una tabla


Cuando se añade una tabla en el Gestor de datos, a la tabla se le asigna un nombre por defecto, basado en el
nombre de la tabla de la base de datos, archivo de datos u hoja Excel, por ejemplo. Si el nombre no es muy
descriptivo o adecuado, puede cambiarlo.

Haga lo siguiente:

1. Haga clic en el nombre de tabla.


2. Edite el nombre de la tabla.
3. Pulse Intro o haga clic fuera del nombre de tabla.

La tabla se ha renombrado.

Renombrar un campo
Puede renombrar los campos de una tabla para obtener un nombre mejor, que sea más fácil de comprender.

Haga lo siguiente:

1. Haga clic en el nombre de campo que desee renombrar, o seleccione Renombrar en el menú del campo.
2. Introduzca el nuevo nombre.

Los nombres de campo deben ser únicos. Si tiene campos con el mismo nombre en varias
tablas, Qlik Sense cualificará los nombres de campo cuando añada datos, es decir, añadirá
el nombre de tabla como prefijo.

3. Pulse la tecla Intro, o haga clic fuera del campo.

El campo se ha renombrado.

Gestionar las asociaciones con otras tablas


Puede crear asociaciones personalizadas a campos de otras tablas con la opción Asociar en el menú del
campo.

Gestión de datos - Qlik Sense, June 2019 50


3   Administrar los datos de la app con el Gestor de datos

Estos son los casos más habituales en los que necesita crear una asociación personalizada en lugar de seguir las
recomendaciones.

l Ya sabe con qué campos asociar las tablas, pero el resultado para este par de tablas es demasiado bajo
como para mostrarlo en la lista de recomendaciones.
Cree una asociación basada en un único campo en cada tabla.
l Las tablas contienen más de un campo común y deben usarse para formar la asociación.
Cree una clave compuesta.

En muchos casos es más fácil gestionar las asociaciones desde la vista de Asociaciones.

Cambiar el tipo de campo y el formato de presentación


Cuando se añaden datos, Qlik Sense interpreta automáticamente el tipo de campo de cada campo. Actualmente
se admiten los siguientes tipos de campos:

l ⏪ General
l G Fecha
l õ Fecha-hora
l , Geodatos

Si los datos no se interpretaron de la forma correcta, puede definir el tipo de campo. También puede cambiar el
formato de entrada y presentación de un campo de datos o de fecha-hora.

Los campos que contienen información geográfica en forma de nombres o códigos, como por ejemplo los
códigos postales, no pueden utilizarse para la correspondencia (o mapeado) a menos que se designen como
campos de Geodatos.

Ocultar campos del análisis


Puede ocultar los campos de la vista de hoja o del asesor de conocimientos para que solo estén disponibles en el
Gestor de datos y el Editor de carga de datos. Por ejemplo, puede tener campos que solo se usen para
calcular otro campo. Puede ocultar estos campos para que no estén disponibles en el panel de activos de las
hojas o desde el asesor de conocimientos, pero que permanezcan disponibles en el Gestor de datos.

Para más información, vea Ocultar campos del análisis (page 72).

Evaluar los datos de campos de tabla antes de cargar los datos


Puede examinar los datos de su tabla para detectar posibles problemas de calidad, como valores nulos y valores
atípicos, antes de cargarlos utilizando el panel Resumen de perfiles de datos. El panel Resumen clasifica los
campos como dimensiones, medidas o campos temporales, proporcionando distintos resúmenes de datos para
cada uno y permitiendo diferentes opciones de transformación en otros paneles de perfiles de datos. Los
campos configurados como medidas en el panel Resumen se pueden agrupar utilizando el panel Cubo. A los
campos configurados como dimensiones en el panel Resumen se les puede aplicar un orden personalizado en
el panel Orden. Para los campos que se pueden clasificar en múltiples categorías, puede alternar entre el
resumen de cada categoría posible para el campo.

Para más información, vea Evaluar los datos de campos de tabla antes de cargar los datos (page 73).

Gestión de datos - Qlik Sense, June 2019 51


3   Administrar los datos de la app con el Gestor de datos

Reemplazar valores de campo en una tabla


Puede reemplazar valores de un campo utilizando el panel de perfiles de datos Reemplazar. El panel
Reemplazar le permite seleccionar uno o más valores de un campo y a continuación reemplazarlos por otro
valor. Por ejemplo, en un conjunto de datos que contenga nombres de países en ambos formatos, completo y
abreviado, podría reemplazarlos por un único valor compartido.

Para más información, vea Reemplazar valores de campo en una tabla (page 75).

Definir valores de campo como nulos en una tabla


Puede configurar distintos valores de un campo de dimensión para que se traten como valores nulos utilizando
el panel de perfiles de datos Definir nulos. El panel Definir nulos le permite seleccionar valores de un campo
de tabla y después configurarlos manualmente como nulos. Por ejemplo, si su conjunto de datos representa
nulos utilizando un carácter como X, puede utilizar el panel Definir nulos para permitir que Qlik Sense trate
ese valor como nulo. El panel Definir nulos también se puede usar para limpiar su conjunto de datos
definiendo valores no deseados como valores nulos.

Para más información, vea Definir valores de campo como nulos en una tabla (page 76).

Configurar un orden personalizado para los valores de campo


Dependiendo de sus datos, puede que le resulte más útil mostrar los valores de dimensión en un orden que no
sea alfabético o numérico. Puede que los campos configurados como dimensiones en el panel Resumen de
perfiles de datos tengan aplicado un orden personalizado de datos mediante el panel Orden de perfiles de
datos, lo cual le permite establecer el esquema predeterminado de los datos de campo en las visualizaciones.

Para más información, vea Personalizar el orden de los valores de dimensión (page 77).

Dividir un campo en una tabla


Puede extraer información de un determinado campo a campos nuevos utilizando el panel de perfiles de datos
Dividir. El panel Dividir permite dividir el contenido de un campo en varios campos. Podría, por ejemplo,
dividir un campo que contenga una dirección para extraer el código postal o la ciudad. Esto le permite crear
rápidamente nuevos campos que contengan secciones relevantes de los datos existentes.

Para más información, vea Dividir un campo en una tabla (page 78).

Agrupar datos de medidas en rangos


Puede agrupar valores de un campo de medida de una tabla en rangos utilizando el panel Cubo de perfiles de
datos. El panel Cubo le permite agrupar el valor de un campo en cubos definidos por el usuario, creando un
nuevo campo que se agrega a la tabla. Podría, por ejemplo, agrupar distintas edades en rangos de edad para
utilizarlos como dimensiones en sus visualizaciones.

Gestión de datos - Qlik Sense, June 2019 52


3   Administrar los datos de la app con el Gestor de datos

Ver detalles de transformación de campo


Puede ver las operaciones actuales y las transformaciones realizadas en un campo y su secuencia en el diálogo
Detalles. Detalles le permite saber de dónde viene un campo, qué cambios se realizaron en el mismo y la
secuencia en la que se aplicaron las transformaciones.

Para más información, vea Ver los detalles de transformación de tablas y campos en el Gestor de datos (page
90).

Despivotar datos de tablas cruzadas


Si ha cargado datos en un formato de tabla cruzada, la mejor opción por lo general es despivotar la tabla, esto
es, trasladar partes de la tabla a filas. Esto hará más fácil trabajar con los datos y creará asociaciones con sus
otras tablas de datos.

Para más información, vea Despivotar datos de una tabla cruzada en el gestor de datos (page 84).

Actualizar una tabla desde la fuente de datos


Puede que desee cambiar la selección de campos desde la fuente de datos. Por ejemplo, puede que necesite
añadir un campo que se quedó fuera, o si la fuente de datos se hubiera actualizado con campos añadidos. En
estos casos, puede actualizar la tabla desde las fuentes de datos. Si la tabla se creó con Entrada manual, puede
añadir, editar o eliminar datos de la tabla, así como agregar nuevas filas y columnas. Para más información,
vea Añadir datos manualmente en Qlik Sense (page 26).

Haga lo siguiente:

1. Haga clic en Seleccionar datos de fuente.


El asistente de selección de datos se abre con sus actuales selecciones.
2. Haga los cambios que necesite en la selección.
3. Haga clic en Añadir datos con el perfilado de datos habilitado.

La tabla se actualiza ahora con campos conforme a las selecciones que ha efectuado.

Añadir un campo calculado


Hay muchas ocasiones en las que necesitamos ajustar o transformar el campo de datos que se carga. Por
ejemplo, es posible que necesitemos concatenar un nombre y un apellido, extraer parte de un número de un
producto, convertir el formato de datos o multiplicar dos números.

Gestión de datos - Qlik Sense, June 2019 53


3   Administrar los datos de la app con el Gestor de datos

Puede añadir campos calculados para que gestionen casos como estos. Un campo calculado utiliza una
expresión para definir el resultado del campo. Puede utilizar campos, funciones y operadores en la expresión.
Solo puede remitir a campos que estén en la tabla que está editando.

Ordenar una tabla


Puede ordenar una tabla por un campo específico mientras está editando la tabla, para obtener una visión
mejor de los datos. Solo se puede ordenar por un campo a la vez.

Haga lo siguiente:

l Desde el menú de campo, seleccione Ordenar.

Los datos de la tabla se ordenan ahora por orden ascendente en relación a este campo. Si desea ordenarlos por
orden descendente, seleccione de nuevo Ordenar.

El orden elegido no se mantiene en los datos cargados en la app.

Las acciones Deshacer y Rehacer


Puede deshacer y rehacer acciones en su tabla haciendo clic en B y C .

El historial de deshacer o rehacer se borra al cerrar el editor de tabla.

Asociar datos en el editor de tablas


Puede crear asociaciones personalizadas a campos de otras tablas con la opción Asociar en el menú del campo
del editor de tablas del Gestor de datos.

En muchos casos es más fácil gestionar sus asociaciones desde la vista de Asociaciones.

Estos son los casos más habituales en los que necesita crear una asociación personalizada en lugar de seguir las
recomendaciones.

l Ya sabe con qué campos asociar las tablas, pero el resultado para este par de tablas es demasiado bajo
como para mostrarlo en la lista de recomendaciones.
Cree una asociación basada en un único campo en cada tabla.
l Las tablas contienen más de un campo común y deben usarse para formar la asociación.
Cree una clave compuesta.

Crear una asociación usando un campo único


Si las dos tablas contienen datos relacionados, pero la asociación no se muestra como recomendada, puede
definir una asociación personalizada en el editor de tabla. Esto crea un campo clave para asociar las tablas.

Haga lo siguiente:

1. Desde la vista general del gestor de datos, haga clic en @ en una de las tablas que desee asociar.
Se abre el editor de tabla.

Gestión de datos - Qlik Sense, June 2019 54


3   Administrar los datos de la app con el Gestor de datos

2. Seleccione Asociar en el menú de campo del campo que desee utilizar en el campo clave.
Se abre el editor Asociar tablas, con una vista previa del campo que ha seleccionado en la tabla
izquierda. Ahora debe seleccionar qué campo asociar con éste en la tabla a mano derecha.
3. Haga clic en Seleccionar tabla y seleccione la tabla a la que asociarlo.
4. Haga clic en P y seleccione el campo con el que asociarlo.
La tabla a mano derecha mostrará una vista previa de datos del campo que seleccionó. Ahora puede
comparar la tabla izquierda con la derecha para ver que contienen datos coincidentes. Puede buscar en
las tablas con F para compararlas más fácilmente.
5. Introduzca un nombre para el campo clave que se creará en Nombre.
No es posible utilizar el mismo nombre de un campo previo en ninguna de las tablas.
6. Haga clic en Asociar.

Las tablas están asociadas ahora por los dos campos que seleccionó, usando un campo clave. Esto se indica
mediante ⏵ . Haga clic en ⏵ para mostrar opciones para editar o romper la asociación.

Crear una clave compuesta


Si dos tablas contienen más de un campo en común, lo cual crearía una asociación, Qlik Sense creará una clave
sintética para gestionar la asociación. La forma recomendada de arreglar esto es creando una clave
compuesta. Esto se logra creando una asociación personalizada que contenga todos los campos que deberían
ir asociados.

Haga lo siguiente:

1. Desde la vista general del gestor de datos, haga clic en @ en una de las tablas que desee asociar.
Se abre el editor de tabla.
2. Seleccione Asociar en el menú de campo de uno de los campos que desee incluir en el campo de la clave
compuesta.
Se abre el editor Asociar tablas, con una vista previa del campo que ha seleccionado en la tabla
izquierda.
3. Haga clic en P para añadir los otros campos que desee incluir en el campo de la clave compuesta.
La vista previa se actualiza con los datos de la clave compuesta.
Ahora debe seleccionar con qué campos asociar éste en la tabla a mano derecha.
4. Haga clic en Seleccionar tabla y seleccione los campos que desee incluir en el campo de la clave
compuesta.
5. Haga clic en P y seleccione el campo con el que asociarlo. Debe seleccionarlos en el mismo orden que
en la tabla de la izquierda.
Para facilitar la interpretación de los datos en la clave también puede delimitar los caracteres.
La tabla a mano derecha mostrará una vista previa de datos del campo que seleccionó.
Ahora puede comparar la tabla izquierda con la derecha para ver que contienen datos coincidentes.
Puede buscar en las tablas con F para compararlas más fácilmente.
6. Introduzca un nombre para el campo clave que se creará en Nombre.
7. Haga clic en Asociar.

Las tablas están asociadas ahora por los campos que seleccionó, usando un campo de clave compuesta.

Gestión de datos - Qlik Sense, June 2019 55


3   Administrar los datos de la app con el Gestor de datos

Limitaciones
Hay algunas limitaciones en cuanto al uso de claves compuestas.

l No es posible crear una clave compuesta en una tabla concatenada.


l Si utiliza un campo calculado en una clave compuesta, la expresión del campo calculado se expande en
la expresión de la clave compuesta. No hay referencia alguna al campo calculado, es decir, que si edita
el campo calculado, la clave compuesta no se actualiza.

Editar una asociación


Puede editar una asociación para renombrarla, o cambiar los campos asociados.

Haga lo siguiente:

1. Haga clic en ⏵ para mostrar el menú de asociaciones.


2. Haga clic en @ para editar la asociación.

Se abre el editor Asociar tablas, y puede renombrar la asociación o cambiar los campos asociados.

Romper una asociación


Si ha creado una asociación no necesaria entre dos tablas, puede romperla.

Haga lo siguiente:

1. Haga clic en ⏵ para mostrar el menú de asociaciones.


2. Haga clic en ⏶ para romper la asociación.

Las tablas ya no están asociadas.

Usar los campos calculados


Hay muchas ocasiones en las que necesitamos ajustar o transformar el campo de datos que se carga. Por
ejemplo, es posible que necesitemos concatenar un nombre y un apellido, extraer parte de un número de un
producto, convertir el formato de datos o multiplicar dos números.

Puede añadir campos calculados para que gestionen casos como estos. Un campo calculado utiliza una
expresión para definir el resultado del campo. Puede utilizar campos, funciones y operadores en la expresión.
Solo puede remitir a campos que estén en la tabla que está editando. Puede hacer referencia a otro campo
calculado en su campo calculado.

Puede añadir y editar campos calculados en el editor de tablas del gestor de datos.

Añadir un campo calculado


Haga lo siguiente:

1. Haga clic en Añadir campo y seleccione Campo calculado.


Se abre el editor para Añadir campo calculado.

Gestión de datos - Qlik Sense, June 2019 56


3   Administrar los datos de la app con el Gestor de datos

2. Introduzca el nombre del campo calculado en Nombre.


3. Defina la expresión del campo calculado en Expresión. Hay dos formas distintas de hacer esto.
l Utilice las 3 listas (Funciones), - (Campos) y ⏩ (Operadores) para seleccionar e insertar
elementos en la expresión.
El elemento que seleccione se inserta en la posición del cursor en Expresión.
l Introduzca la expresión para el campo calculado en Expresión.
A medida que escriba, va obteniendo ayuda con funciones y campos sugeridos, así como sintaxis
de funciones.
Los resultados, a modo de ejemplo, del campo calculado se muestran en la Vista previa.
4. Haga clic en Crear para crear el campo calculado y cierre el editor del campo calculado.

Editar un campo calculado


Puede cambiar el nombre o editar la expresión de un campo calculado.

Haga lo siguiente:

1. Seleccione Editar en el menú desplegable junto al nombre de campo.


Se abre el editor para Actualizar campo calculado.
2. Edite el nombre del campo calculado en Nombre si desea cambiarlo.
3. Edite la expresión del campo calculado.
4. Haga clic en Actualizar para actualizar el campo calculado y cierre el editor del campo calculado.

¿Qué funciones puedo utilizar en una expresión de campo calculado?


Puede utilizar las funciones que aquí se enumeran cuando cree una expresión de campo calculado. Este es un
subconjunto de las expresiones disponibles en el script de carga de datos. La expresión no puede dar como
resultado ninguna agregación de datos de varios registros, ni utilizar funciones inter-registro para remitir a
datos de otros registros.

Funciones de cadena de texto que pueden utilizarse en una expresión de campo calculado
Estas funciones se pueden utilizar para modificar o extraer datos en formato de cadena de texto.

Funciones de cadena
Función Descripción

Capitalize Capitalize() devuelve la cadena con todas las palabras con su letra inicial en
mayúscula.

Chr Chr() devuelve el carácter Unicode correspondiente al número entero introducido.

FindOneOf FindOneOf() busca una cadena a fin de hallar la posición de cualquier carácter de un
conjunto de caracteres suministrados. Devuelve la posición de la primera vez que
aparece cualquier carácter del conjunto especificado en la búsqueda, a menos que se
suministre un tercer argumento (con un valor mayor que 1). Si no encuentra ningún
resultado, devuelve 0.

Gestión de datos - Qlik Sense, June 2019 57


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

Index Index() busca una cadena para hallar la posición de inicio de la enésima vez que
aparece una subcadena suministrada. Un tercer argumento opcional proporciona el
valor de n, el cual se considera 1 si se omite. Un valor negativo busca desde el final de la
cadena. Las posiciones en la cadena están numeradas de 1 en adelante.

KeepChar KeepChar() devuelve una cadena que consiste en la primera cadena, 'text', menos
cualquiera de los caracteres NO contenidos en la segunda cadena, "keep_chars".

Left Left() devuelve una cadena que consiste en los primeros caracteres (los situados más a
la izquierda) de la cadena introducida, donde el número de caracteres viene
determinado por el segundo argumento.

Len Len() devuelve la longitud de la cadena introducida.

Lower Lower() pone todos los caracteres de la cadena introducida en letra minúscula.

LTrim LTrim() devuelve la cadena introducida sin los espacios iniciales.

Mid Mid() devuelve la parte de la cadena de entrada que comienza en la posición del
carácter definido por el segundo argumento, 'start', y devolviendo el número de
caracteres definidos por el tercer argumento, 'count'. Si 'count' se omite, devuelve el
resto de la cadena de entrada. El primer carácter de la cadena de entrada se enumera
como 1.

Ord Ord() devuelve el número Unicode de punto de código del primer carácter de la cadena
de entrada.

PurgeChar PurgeChar() devuelve una cadena que contiene los caracteres de la cadena introducida
('text'), menos los caracteres que aparecen en el segundo argumento ('remove_chars').

Repeat Repeat() forma una cadena que consiste en la cadena introducida, repetida el número
de veces definido por el segundo argumento.

Replace Replace() devuelve una cadena tras haber reemplazado todas las veces en que aparece
una determinada subcadena dentro de la cadena introducida por otra subcadena. La
función no es recursiva y funciona de izquierda a derecha.

Right Right() devuelve una cadena que consta de los últimos caracteres (situados más a la
derecha) de la cadena de entrada, donde el número de caracteres viene determinado
por el segundo argumento.

RTrim RTrim() devuelve la cadena introducida libre de espacios finales.

SubStringCount() devuelve el número de veces que aparece la subcadena especificada


SubStringCount en el texto de la cadena de entrada. Si no existe coincidencia alguna, devuelve 0.

TextBetween TextBetween() devuelve el texto de la cadena de entrada que se da entre los caracteres
especificados como delimitadores.

Trim Trim() devuelve la cadena introducida libre de todos los espacios iniciales y finales.

Upper Upper() convierte todos los caracteres de la cadena introducida en mayúscula para
todos los caracteres de texto de la expresión. Los números y símbolos se ignoran.

Gestión de datos - Qlik Sense, June 2019 58


3   Administrar los datos de la app con el Gestor de datos

Funciones de fecha que pueden utilizarse en una expresión de campo calculada


Las funciones de fecha y hora de Qlik Sense se usan para transformar y convertir valores de fecha y hora.

Las funciones están basadas en un número de serie de fecha-hora que es igual al número de días transcurridos
desde el 30 de diciembre de 1899. El valor entero representa el día, y el valor fraccional representa la hora del
día.

Qlik Sense utiliza el valor numérico del argumento, por tanto, un número es válido también como argumento
cuando no tiene formato de fecha u hora. Si el argumento no se corresponde con un valor numérico, por ej. si
fuera una cadena, entonces Qlik Sense trata de interpretar la cadena conforme a las variables de fecha y hora
del sistema operativo.

Si el formato de fecha utilizado en el argumento no se corresponde con el establecido en la variable de sistema


DateFormat, Qlik Sense no podrá realizar una interpretación correcta de la fecha. Para resolver este problema,
modifique la configuración o bien utilice una función de interpretación.

Funciones de fecha
Función Descripción

addmonths Esta función devuelve la fecha que figura n meses después de startdate o, si n es
negativa, la fecha que figura n meses antes de startdate.

addyears Esta función devuelve la fecha que aparece n años después de startdate o, si n es
negativa, la fecha que aparece n años antes de startdate.

age La función age devuelve la edad en el momento timestamp (en años completos)
de una persona nacida el día date_of_birth .

converttolocaltime Convierte una fecha-hora UTC o GMT en la fecha y hora local como un valor dual.
El lugar puede ser cualquier ciudad, población o zona horaria del mundo. 

day Esta función devuelve un entero que representa el día en que la fracción de
expression se interpreta como una fecha de acuerdo con la interpretación
numérica estándar.

dayend Esta función devuelve un valor correspondiente a una marca de tiempo (una
fecha-hora) del milisegundo final del día contenido en time. El formato de salida
predeterminado será el TimestampFormat establecido en el script.

daylightsaving Convierte una fecha-hora UTC o GMT en la fecha y hora local como un valor dual.
El lugar puede ser cualquier ciudad, población o zona horaria del mundo. 

dayname Esta función devuelve un valor que muestra la fecha con un valor numérico
subyacente correspondiente a una marca de tiempo (fecha-hora) del primer
milisegundo del día que contiene a time.

Convierte una fecha-hora UTC o GMT en la fecha y hora local como un valor dual.
daynumberofquarter El lugar puede ser cualquier ciudad, población o zona horaria del mundo. 

Gestión de datos - Qlik Sense, June 2019 59


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

daynumberofyear Esta función calcula el número de día del año en el que cae una fecha-hora. El
cálculo se hace a partir del primer milisegundo del primer día del año, pero el
primer mes puede desplazarse.

daystart Esta función devuelve un valor correspondiente a una marca de tiempo (fecha-
hora) con el primer milisegundo del día contenido en el argumento time. El
formato de salida predeterminado será el TimestampFormat establecido en el
script.

firstworkdate La función firstworkdate devuelve la última fecha de inicio para obtener un no_
of_workdays (de lunes a viernes) sin sobrepasar end_date teniendo en cuenta la
lista opcional de vacaciones. end_date y holiday deben ser fechas y horas
válidas.

GMT Esta función devuelve la hora actual de Greenwich Mean Time, según se deriva del
reloj del sistema y las configuraciones horarias de Windows.

hour Esta función devuelve un entero que representa la hora en que la fracción de
expression se interpreta como una hora de acuerdo con la interpretación
numérica estándar.

inday Esta función devuelve True si timestamp se encuentra dentro del día que contiene
a base_timestamp.

indaytotime Esta función devuelve True si timestamp se encuentra dentro de la parte del día
que contiene a base_timestamp hasta e incluido el milisegundo exacto de base_
timestamp.

inlunarweek Esta función halla si timestamp se encuentra dentro de la semana lunar que
contiene la fecha base base_date. Las semanas lunares en Qlik Sense se definen
contando 1 de enero como el primer día de la semana.

inlunarweektodate Esta función halla si timestamp se encuentra dentro de la parte de la semana


lunar hasta e incluido el último milisegundo de base_date. Las semanas lunares
en Qlik Sense se definen contando 1 de enero como el primer día de la semana.

inmonth Esta función devuelve True si timestamp se encuentra dentro del mes que
contiene a base_date.

inmonths Esta función encuentra si una indicación de fecha y hora cae dentro del mismo
mes, periodo de dos meses, trimestre, cuatrimestre o semestre dado como una
fecha base. También es posible hallar si la fecha-hora cae dentro de un periodo de
tiempo anterior o posterior.

inmonthstodate Esta función encuentra si una marca de tiempo (fecha-hora) cae dentro de la parte
del período de un mes, dos meses, tres meses, cuatro meses o medio año hasta e
incluido el último milisegundo de base_date. También es posible hallar si la fecha-
hora cae dentro de un periodo anterior o posterior.

Gestión de datos - Qlik Sense, June 2019 60


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

inmonthtodate Devuelve True si date se encuentra dentro de la parte del mes que contiene a
basedate hasta e incluido el último milisegundo de basedate.

inquarter Esta función devuelve True si timestamp se encuentra dentro del trimestre que
contiene a base_date.

inquartertodate Esta función devuelve True si timestamp se encuentra dentro de la parte del
trimestre que contiene a base_date hasta e incluido el último milisegundo de
base_date.

inweek La función devuelve True si timestamp se encuentra dentro de la semana que


contiene a base_date.

inweektodate Esta función devuelve True si timestamp se encuentra dentro de la parte de la


semana que contiene a base_date hasta e incluido el último milisegundo de
base_date.

inyear Esta función devuelve True si timestamp se encuentra dentro del año que contiene
a base_date.

inyeartodate Esta función devuelve True si timestamp se encuentra dentro de la parte del año
que contiene a base_date hasta e incluido el último milisegundo de base_date.

lastworkdate La función lastworkdate devuelve la fecha más temprana de finalización para


obtener el no_of_workdays (lunes-viernes) si comienza en start_date y teniendo
en cuenta cualquier periodo vacacional opcionalmente indicado holiday. start_
date y holiday deben ser fechas o fecha-hora válidas. 

localtime Esta función devuelve una fecha y hora con la hora actual según el reloj del
sistema y una determinada zona horaria.

lunarweekend Esta función devuelve un valor correspondiente a la marca de tiempo (fecha-hora)


del último milisegundo de la semana lunar que contiene a date. Las semanas
lunares en Qlik Sense se definen contando 1 de enero como el primer día de la
semana.

lunarweekname Esta función devuelve un valor de visualización que muestra el año y el número de
la semana lunar correspondiente a una marca de tiempo (fecha-hora) del primer
milisegundo del primer día de la semana lunar que contiene a date. Las semanas
lunares en Qlik Sense se definen contando 1 de enero como el primer día de la
semana.

lunarweekstart Esta función devuelve un valor correspondiente a una marca de tiempo (fecha-
hora) del primer milisegundo de la semana lunar que contiene a date. Las
semanas lunares en Qlik Sense se definen contando 1 de enero como el primer día
de la semana.

makedate Esta función devuelve una fecha calculada a partir del año YYYY, el mes MM y el
día DD.

Gestión de datos - Qlik Sense, June 2019 61


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

maketime Esta función devuelve una hora calculada a partir de la hora hh , el minuto mm y
el segundo ss.

makeweekdate Esta función devuelve una fecha calculada a partir del año YYYY, la semana WW y
el día de la semana D.

minute Esta función devuelve un entero que representa el minuto en que la fracción de la
expression se interpreta como una hora de acuerdo con la interpretación
numérica estándar.

month Esta función devuelve un valor dual: un nombre de mes tal como se define en la
variable de entorno MonthNames y un entero entre 1-12. El mes se calcula a partir
de la interpretación de la fecha de la expresión, conforme a la interpretación
numérica estándar.

monthend Esta función devuelve un valor correspondiente a una marca de tiempo (fecha-
hora) del último milisegundo del último día del mes que contiene a date. El
formato de salida predeterminado será el DateFormat establecido en el script.

monthname Esta función devuelve un valor de visualización que muestra el mes (con formato
de acuerdo con la variable de script MonthNames) y el año con un valor numérico
subyacente correspondiente a una marca de tiempo (fecha-hora) del primer
milisegundo del primer día del mes.

monthsend Esta función devuelve un valor correspondiente a una fecha y hora con el último
milisegundo del mes, periodo de dos meses, trimestre, cuatrimestre o semestre que
engloba la fecha base. También es posible hallar la fecha-hora de un periodo
anterior o posterior.

monthsname Esta función devuelve un valor de visualización que representa el rango de los
meses del período (con formato de acuerdo con la variable de script
MonthNames), así como el año. El valor numérico subyacente corresponde a la
fecha y hora del primer milisegundo del mes, periodo de dos meses, trimestre,
cuatrimestre o semestre que contiene la fecha base.

monthsstart Esta función devuelve un valor correspondiente a la fecha y hora del primer
milisegundo del mes, periodo de dos meses, trimestre, cuatrimestre o semestre que
contiene la fecha base. También es posible hallar la fecha-hora de un periodo
anterior o posterior.

monthstart Esta función devuelve un valor correspondiente a una marca de tiempo (fecha-
hora) del primer milisegundo del primer día del mes que contiene a date. El
formato de salida predeterminado será el DateFormat establecido en el script.

networkdays La función networkdays devuelve el número de días laborables (de lunes a


viernes) entre e incluidos los días start_date y end_date teniendo en cuenta
cualquier listado opcional de vacaciones: holiday.

Gestión de datos - Qlik Sense, June 2019 62


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

now Esta función devuelve una fecha-hora con la hora actual según el reloj del sistema.
El valor predeterminado es 1.

quarterend Esta función devuelve un valor correspondiente a una marca de tiempo del último
milisegundo del trimestre que contiene a date. El formato de salida
predeterminado será el DateFormat establecido en el script.

quartername Esta función devuelve un valor de visualización que muestra los meses del
trimestre (con formato conforme a la variable de script MonthNames) y el año
con un valor numérico subyacente correspondiente a una marca de tiempo (una
fecha-hora) del primer milisegundo del primer día del trimestre.

quarterstart Esta función devuelve un valor correspondiente a una marca de tiempo con el
primer milisegundo del trimestre que contiene a date. El formato de salida
predeterminado será el DateFormat establecido en el script.

second Esta función devuelve un entero que representa el segundo en que la fracción de
expression se interpreta como una hora de acuerdo con la interpretación
numérica estándar.

timezone Esta función devuelve el nombre de la zona horaria actual, como se define en
Windows.

today Esta función devuelve la fecha actual según el reloj del sistema.

UTC Devuelve la hora Coordinated Universal Time actual.

week Esta función devuelve un entero que representa el número de semana conforme a
la ISO 8601. El número de semana se calcula a partir de la interpretación de la
fecha de la expresión, conforme a la interpretación numérica estándar.

weekday Esta función devuelve un valor dual con lo siguiente: Un nombre de día tal como se
define en la variable de entorno DayNames. Un número entero entre 0 y 6
correspondiente al día nominal de la semana (0-6).

weekend Esta función devuelve un valor correspondiente a una marca de tiempo (fecha-
hora) del último milisegundo del último día (domingo) de la semana del calendario
que contiene a date. El formato de salida predeterminado será el formato de
fecha DateFormat definido en el script.

weekname Esta función devuelve un valor que muestra el número de año y de semana con un
valor numérico subyacente correspondiente a una marca de tiempo del primer
milisegundo del primer día de la semana que contiene a date.

weekstart Esta función devuelve un valor correspondiente a una marca de tiempo del primer
milisegundo del primer día (lunes) de la semana de calendario que contiene a
date. El formato de salida predefinido es el DateFormat definido en el script.

weekyear Esta función devuelve el año al que pertenece el número de semana conforme a la
ISO 8601. El número de semana varía entre 1 y 52 aproximadamente.

Gestión de datos - Qlik Sense, June 2019 63


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

year Esta función devuelve un entero que representa el año en que expression se
interpreta como una fecha de acuerdo con la interpretación numérica estándar.

yearend Esta función devuelve un valor correspondiente a una marca de tiempo del último
milisegundo del último día del año que contiene a date. El formato de salida
predeterminado será el DateFormat definido en el script.

yearname Esta función devuelve un año de cuatro dígitos como valor de visualización con un
valor numérico subyacente correspondiente a una marca de tiempo (fecha-hora)
del primer milisegundo del primer día del año que contiene date.

yearstart Esta función devuelve una marca de tiempo correspondiente al inicio del primer
día del año que contiene a date. El formato de salida predefinido será el
DateFormat definido en el script.

yeartodate Esta función encuentra si la marca de tiempo (una fecha-hora) de entrada se


encuentra dentro del año de la fecha en que se cargó el script por última vez, y
devuelve True si lo hace o False si no lo hace.

Funciones de formato e interpretación que pueden utilizarse en una expresión de campo


calculada
Las funciones de formato utilizan el valor numérico de la expresión de entrada y lo convierten en un valor de
texto. Por el contrario, las funciones de interpretación toman expresiones de cadena y devuelven números,
especificando el formato del número resultante. En ambos casos el valor de salida es dual, con un valor de texto
y un valor numérico.

Por ejemplo, vea las diferencias en los datos de salida entre las funciones Date y Date#.

Funciones Date y Date#


Función Datos de salida (texto) Datos de salida (numérico)
Date#('20140831', 'YYYYMMDD') 20140831 41882
Date(41882, 'YYYY.MM.DD') 2014.08.31 41882

Estas funciones son útiles cuando sus datos contienen campos de fecha que no se interpretan como fechas
puesto que el formato no se corresponde con el formato de fecha establecido en Qlik Sense. En este caso, puede
resultar útil anidar las funciones:

Date(Date#(DateInput, 'YYYYMMDD'),'YYYY.MM.DD')
Esto interpretará el campo DateInput de acuerdo con el formato de entrada, YYYYMMDD, y lo devolverá en el
formato que desee utilizar, YYYY.MM.DD.

Gestión de datos - Qlik Sense, June 2019 64


3   Administrar los datos de la app con el Gestor de datos

Funciones de interpretación y formato


Función Descripción

Date Date() da formato a una expresión como una fecha utilizando el formato establecido en las
variables de sistema del script de carga de datos, o en el sistema operativo, o en una cadena
de formato, si se proporciona.

Date# Date# devuelve una expresión como una fecha en el formato especificado en el segundo
argumento, si se proporciona este.

Dual Dual() combina un número y una cadena en un solo registro, de manera que la
representación numérica del registro se puede utilizar con fines de ordenación y cálculo,
mientras que el valor de la cadena se puede usar para fines de visualización.

Interval Interval() da formato a un número como un intervalo de tiempo utilizando el formato


establecido en las variables de sistema del script de carga de datos, o el sistema operativo, o
una cadena de formato, si se suministra.

Interval# Interval#() devuelve una expresión de texto como un intervalo de tiempo en el formato
establecido por defecto en el sistema operativo, o en el formato especificado en el segundo
argumento, si se proporciona este.

Money Money() da formato numérico a una expresión con el valor de moneda, en el formato
numérico establecido en las variables de sistema del script de carga de datos o en el sistema
operativo, a menos que se suministre una cadena de formato y, opcionalmente, unos
separadores decimal y de miles.

Money# Money#() convierte una cadena de texto en un valor de moneda, en el formato definido en
el script de carga o el sistema operativo, a menos que se suministre una cadena de formato.
Los símbolos de separador decimal o de miles personalizados son parámetros opcionales.

Num Num() da formato numéricamente a una expresión en el formato de número establecido en


las variables de sistema del script de carga de datos, o en el sistema operativo, a menos que
se suministre una cadena de formato y, opcionalmente, unos separadores decimal y de
miles.

Num# Num#() convierte una cadena de texto en un valor numérico, en el formato numérico
establecido en el script de carga de datos o el sistema operativo. Los símbolos de separador
decimal o de miles personalizados son parámetros opcionales.

Text Text() obliga a que la expresión se trate como texto, incluso si es posible una interpretación
numérica.

Time Time() da formato a una expresión como un valor de hora, en el formato de tiempo
definido en las variables de sistema del script de carga de datos, o en el sistema operativo, a
menos que se suministre una cadena de formato.

Time# Time#() evalúa una expresión como un valor de tiempo, en el formato de tiempo
establecido en el script de carga de datos o en el sistema operativo, a menos que se
proporcione una cadena de formato.

Gestión de datos - Qlik Sense, June 2019 65


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

Timestamp TimeStamp() da formato a una expresión como un valor de fecha y hora, en el formato de
tiempo definido en las variables de sistema del script de carga de datos, o el sistema
operativo, a menos que se proporcione una cadena de formato.

Timestamp#() evalúa una expresión como un valor de fecha y hora, en el formato de


Timestamp# tiempo establecido en el script de carga de datos o en el sistema operativo, a menos que se
proporcione una cadena de formato.

Funciones numéricas que pueden utilizarse en una expresión de campo calculada


Puede utilizar estas funciones para redondear valores numéricos.

Funciones numéricas
Función Descripción

ceil Ceil() redondea un número hacia arriba, hacia el múltiplo más cercano de step desplazado por
el número offset .

div Div() devuelve la parte entera de la división aritmética del primer argumento por el segundo
argumento. Ambos parámetros se interpretan como números reales, esto es, no tienen que ser
enteros.

evens Even() devuelve True (-1), si integer_number es un entero par o cero. Devuelve False (0), si
integer_number es un entero impar y NULL si integer_number no es un entero.

fabs Fabs() devuelve el valor absoluto de x. El resultado es un número positivo.

fact Fact() devuelve el factorial de un entero positivo x.

floor Floor() redondea un número hacia abajo, hacia el múltiplo más cercano de step desplazado por
el número offset .

fmod fmod() es una función de módulo generalizada que devuelve la parte restante de la división
entera del primer argumento (el dividendo) por el segundo argumento (el divisor). El resultado es
un número real. Ambos argumentos se interpretan como números reales, esto es, no tienen que
ser enteros.

frac Frac() devuelve la parte x de la fracción.

mod Mod() es una función matemática de módulo que devuelve el resto no negativo de una división
de un entero. El primer argumento es el dividendo y el segundo argumento es el divisor. Ambos
argumentos deben ser valores enteros.

odd Odd() devuelve True (-1), si integer_number es un entero impar o cero. Devuelve False (0), si
integer_number es un entero par, y NULL si integer_number no es un entero.

round Round() devuelve el resultado de redondear un número hacia arriba o hacia abajo al múltiplo
más cercano de step desplazado por el número offset .

sign Sign() devuelve 1, 0 o -1 dependiendo de si x es un número positivo, 0 o un número negativo.

Gestión de datos - Qlik Sense, June 2019 66


3   Administrar los datos de la app con el Gestor de datos

Funciones condicionales que pueden utilizarse en una expresión de campo calculada


Puede usar estas funciones para evaluar una condición y después devolver distintas respuestas dependiendo del
valor de la condición.

Funciones condicionales
Función Descripción

alt La función alt devuelve el primero de los parámetros que tiene una representación numérica
válida. Si no se encuentra tal condición, devolverá el último parámetro. Se puede utilizar
cualquier número de parámetros.

class La función class asigna el primer parámetro a un intervalo de clases. El resultado es un valor
dual con a<=x<b como el valor textual, donde a y b son los límites superior e inferior del
contenedor, y el límite inferior como valor numérico.

if La función if devuelve un valor dependiendo de si la condición proporcionada con la función


se evalúa como True o False.

match La función match compara el primer parámetro con todos los siguientes y devuelve la
ubicación numérica del número de expresiones que coinciden. La comparación es sensible a
mayúsculas.

mixmatch La función mixmatch compara el primer parámetro con todos los siguientes y devuelve la
ubicación numérica de las expresiones que coinciden. La comparación no es sensible a
mayúsculas.

pick La función de selección devuelve la enésima expresión n en la lista.

La función wildmatch compara el primer parámetro con todos los siguientes y devuelve el
wildmatch número de la expresión que coincida. Permite el uso de los caracteres comodín ( * y ?) en las
cadenas de comparación. * es cualquier secuencia de caracteres. ? es un único carácter.

Funciones NULL que se pueden utilizar en una expresión de campo calculada


Puede utilizar estas funciones para devolver o detectar valores nulos.

Funciones NULL
Función Descripción

Null La función Null devuelve un valor NULL.

IsNull La función IsNull comprueba si el valor de una expresión es NULL y, si lo es, devuelve -1 (True), de
lo contrario, devuelve 0 (False).

Funciones matemáticas que se pueden utilizar en una expresión de campo calculada


Puede usar estas funciones para cálculos matemáticos.

Gestión de datos - Qlik Sense, June 2019 67


3   Administrar los datos de la app con el Gestor de datos

Funciones matemáticas
Función Descripción

e La función devuelve la base de los logaritmos naturales, e ( 2.71828...).

rand La función devuelve un número aleatorio entre 0 y 1. Esto se puede usar para crear datos de
muestra.

Funciones exponenciales y logarítmicas que se pueden utilizar en una expresión de campo


calculada
Puede usar estas funciones para cálculos exponenciales y logarítmicos.

Funciones exponenciales y logarítmicas


Función Descripción

exp La función exponencial natural, e^x, usando el logaritmo natural e como base. El resultado es un
número positivo.

log El logaritmo natural de x. La función solo se define si x> 0. El resultado es un número.

log10 El logaritmo común (base 10) de x. La función solo se define si x> 0. El resultado es un número.

pow Devuelve x a la potencia de y. El resultado es un número.

sqr x al cuadrado (x a la potencia de 2). El resultado es un número.

sqrt Raíz cuadrada de x. La función solo se define si x >= 0. El resultado es un número positivo.

Funciones de distribución que se pueden utilizar en una expresión de campo calculada


Puede usar estas funciones para cálculos de distribución estadística.

Funciones de distribución
Función Descripción

CHIDIST CHIDIST() devuelve la probabilidad de una cola de la distribución chi2. La distribución chi2 se
asocia con una prueba chi2.

CHIINV CHIINV() devuelve el inverso de la probabilidad de una cola de la distribución de chi2.

FDIST FDIST() devuelve la distribución de probabilidad F.

FINV FINV() devuelve el inverso de la distribución de probabilidad F.

NORMDIST() devuelve la distribución normal acumulativa de la media y la desviación


NORMDIST estándar especificadas. Si mean = 0 y standard_dev = 1, la función devuelve la distribución
normal estándar.

NORMINV NORMINV() devuelve el inverso de la distribución acumulativa normal de la media y la


desviación estándar especificadas.

TDIST TDIST() devuelve la probabilidad de distribución t de estudiante, en la que un valor numérico


es un valor calculado de t para el cual se ha de calcular la probabilidad.

Gestión de datos - Qlik Sense, June 2019 68


3   Administrar los datos de la app con el Gestor de datos

Función Descripción

TINV TINV() devuelve el valor t de la distribución t de estudiante como una función de la


probabilidad y los grados de libertad.

Funciones geoespaciales que se pueden utilizar en una expresión de campo calculada


Puede usar esta función para manejar datos geoespaciales.

Funciones geoespaciales
Función Descripción

GeoMakePoint() se utiliza en scripts y expresiones de gráfico para crear y etiquetar un


GeoMakePoint punto con la latitud y la longitud.

Funciones de color que se pueden utilizar en una expresión de campo calculada


Puede usar estas funciones para configurar y evaluar propiedades de color.

Funciones de color
Función Descripción

ARGB ARGB() se utiliza en expresiones para fijar o evaluar las propiedades de color de un objeto
gráfico, donde el color viene definido por un componente de rojo r, un componente de verde g y
un componente de azul b, con un factor alfa (opacidad) de alpha.

HSL HSL() se utiliza en las expresiones para fijar o evaluar las propiedades de color de un objeto
gráfico, donde el color se define mediante los valores de hue, saturation y luminosity entre 0 y
1.

RGB RGB() se utiliza en las expresiones para fijar o evaluar las propiedades de color de un objeto
gráfico, donde el color viene definido por un componente de rojo r, un componente de verde g y
un componente de azul b con valores entre 0 y 255.

Funciones lógicas que se pueden utilizar en una expresión de campo calculada


Puede usar estas funciones para manejar operaciones lógicas.

Funciones lógicas
Función Descripción

IsNum Devuelve -1 (True) si la expresión puede interpretarse como un número, de lo contrario devuelve 0
(False).

IsText Devuelve -1 (True) si la expresión tiene una representación de texto, de lo contrario devuelve 0
(False).

Funciones del sistema que se pueden utilizar en una expresión de campo calculada
Puede usar estas funciones para acceder a las propiedades del sistema, del dispositivo y de la app de Qlik Sense.

Gestión de datos - Qlik Sense, June 2019 69


3   Administrar los datos de la app con el Gestor de datos

Funciones de sistema
Función Descripción

OSUser Esta función devuelve una cadena que contiene el nombre del usuario actualmente
conectado. Puede utilizarse tanto en el script de carga de datos como en una expresión de
gráficos.

Esta función devuelve una fecha-hora indicando el momento en que finalizó la última carga
ReloadTime de datos. Puede utilizarse tanto en el script de carga de datos como en una expresión de
gráficos.

Cambiar los tipos de campos


Cuando se añaden datos, Qlik Sense interpreta automáticamente el tipo de campo de cada campo. Actualmente
se admiten los siguientes tipos de campos:

l ⏪ General
l G Fecha
l õ Fecha-hora
l , Geodatos

Si los datos no se interpretaron de la forma correcta, puede definir el tipo de campo. También puede cambiar el
formato de entrada y presentación de un campo de datos o de fecha-hora.

Para abrir el editor de tabla, haga clic en @ en la tabla de datos que desee editar.

No es posible cambiar el tipo de campo o el formato de presentación de campos en algunos casos.

l La tabla es el resultado de concatenar dos o más tablas.


l El campo ya se reconoce como una fecha o fecha-hora.

Asegurarse de que un campo de fecha o fecha-hora se reconozca adecuadamente


Si un campo de fecha o fecha-hora no se reconoce como una fecha o fecha-hora, es decir, está marcado con
⏪ General, puede asegurarse de que se interprete correctamente.

Haga lo siguiente:

1. Haga clic en ⏪ sobre la cabecera del campo.


Se abre el cuadro de diálogo de formato de datos.
2. Cambie Tipo de campo a Fecha o Fecha-hora.
3. Cambie la cadena de formato en Formato de entrada para que interprete la fecha correctamente.
Puede usar un formato ya preparado de la lista desplegable, o escribir su propia cadena de formato.

No es posible utilizar un signo de entrecomillado simple en el código de formato.

4. Si desea utilizar un formato de presentación distinto del formato predefinido en su app, escriba o

Gestión de datos - Qlik Sense, June 2019 70


3   Administrar los datos de la app con el Gestor de datos

seleccione una cadena de formato en Formato de presentación .


Si lo deja vacío, se utilizará el formato de presentación predefinido en la app.

Cambiar el formato de presentación de un campo de fecha o fecha-hora


Cada app tiene unos formatos predefinidos para campos de fecha y fecha-hora. Puede cambiar el formato de
presentación de un campo individual de fecha o fecha-hora.

Haga lo siguiente:

1. Haga clic en G (fecha) o õ (fecha-hora) sobre la cabecera del campo.


Se abre el cuadro de diálogo de formato de datos.
2. Cambie la cadena de formato en Formato de presentación. Puede usar un formato ya preparado de
la lista desplegable, o escribir su propia cadena de formato.

Cambiar un tipo de campo a datos geográficos


Si un campo con valores tales como nombres de ciudades y países o símbolos ISO no se reconoce como datos
geográficos, puede cambiar el tipo de campo a Geodatos.

Haga lo siguiente:

1. Haga clic en ⏪ sobre la cabecera del campo.


Se abre el cuadro de diálogo de formato de datos.
2. Seleccione Geodatos en el menú desplegable Tipo de campo.
3. Seleccione el tipo de datos geográficos en el menú desplegable Geodatos.
Las opciones son Ciudad, País, Código de país ISO2 y Código de país ISO3. ISO2 y ISO3 pertenecen
a la ISO 3166, los códigos de la Organización Internacional de Normalización para países. ISO2 contiene
códigos de dos caracteres y ISO3 contiene códigos de tres caracteres. Por ejemplo, los códigos de Suiza
son SE y SWE.
Al asignar un código ISO, asegúrese de que los valores del campo coincidan con el código que asigna. Si
asigna ISO3 a un campo con valores de código de dos caracteres, las coordenadas de ubicación no se
asignarán correctamente.
4. Para datos de Ciudad, seleccione el campo relacionado en la tabla que contiene datos geográficos para
los países.
Puede que haya solo un campo de país relacionado, pero es posible tener múltiples campos con datos
geográficos de países. Por ejemplo, un campo puede tener nombres largos como Francia y otro campo
que designe países por códigos de país como ISO2. Pero los campos aparecen en la lista de Países
asociados solo si han sido designados como Geodatos.
Si no se ha designado ningún campo como campo de país con Geodatos, la lista de Países asociados
no aparece cuando se designa un campo como Ciudad.

Cuando el usuario, o bien Qlik Sense de forma automática, asignan un campo al tipo de campo Geodatos, se le
asocia un campo que contiene coordenadas geográficas, ya sean datos de puntos o polígonos. Los campos
asociados que contienen las coordenadas están visibles en el Visor del modelo de datos. Estas coordenadas
son necesarias para apps que utilicen objetos de Mapa.

Gestión de datos - Qlik Sense, June 2019 71


3   Administrar los datos de la app con el Gestor de datos

Los campos que contienen información geográfica en forma de nombres o códigos, como por ejemplo los
códigos postales, no pueden utilizarse para la correspondencia (o mapeado) a menos que se designen como
campos de Geodatos.

Los campos asignados al tipo Geodatos siguen conteniendo valores de cadena, como México y MX, pero
cuando se usan en un objeto de Mapa, las coordenadas de mapa provienen de los campos que contienen los
datos de puntos o polígonos.

Ocultar campos del análisis


Puede ocultar campos de datos que no desee que estén disponibles cuando crea visualizaciones en la vista de
hoja o en el asesor de conocimientos. Por ejemplo, puede tener campos que solo se usen para calcular otro
campo. Puede ocultar estos campos en el Gestor de datos para que no estén disponibles en el panel de activos
de las hojas o desde el asesor de conocimientos, pero permanezcan disponibles en el Gestor de datos y el
Editor de carga de datos. Esto puede servir para eliminar información que resulte redundante o innecesaria
en su análisis o información actual, incluyendo solo la información relevante, facilitando así su lectura y
análisis.

Al ocultar un campo, se mantendrán todas las relaciones existentes que tenga el campo, como asociaciones o
uso en cálculos. Si un campo está actualmente en uso, por ej. en un elemento maestro o en un gráfico, seguirá
estando disponible ahí, pero no estará disponible para su uso en nuevos elementos maestros o visualizaciones
hasta que se muestre de nuevo.

Puede ver todos sus campos ocultos del Gestor de datos dirigiéndose al Editor de carga de datos
y abriendo la sección autogenerada. Todos los campos ocultos se mostrarán como TAG FIELD
<nombre campo>. WITH '$hidden';

Ocultar un campo del análisis


Haga lo siguiente:

1. Haga clic en Ô sobre la cabecera del campo.


2. Haga clic en Ocultar en análisis.

El campo ahora está oculto en la vista de hoja y en el asesor de conocimientos. Los campos ocultos tienen un
signo † encima de la cabecera del campo.

Mostrar un campo oculto


Haga lo siguiente:

1. Haga clic en Ô o † encima de la cabecera del campo.


2. Haga clic en Mostrar en análisis.

El campo ahora está disponible en la vista de hoja y en el asesor de conocimientos. El † sobre la cabecera del
campo se eliminará.

Gestión de datos - Qlik Sense, June 2019 72


3   Administrar los datos de la app con el Gestor de datos

Evaluar los datos de campos de tabla antes de cargar los datos


A fin de examinar los datos para detectar posibles problemas de calidad, como valores nulos o atípicos, antes de
cargar los datos en Qlik Sense verá un resumen de los datos en el panel Resumen de datos. Además, el panel
Resumen le permite ver distintas interpretaciones posibles de los datos, como por ejemplo, ver los datos del
campo como una dimensión o medida.

Al panel Resumen se accede editando una tabla en el Gestor de datos y seleccionando un campo de tabla.
Cuando se selecciona un campo en el editor de tablas, Qlik Sense examina el tipo de datos, los metadatos y los
valores presentes. El campo se clasifica entonces como una dimensión, una medida o un campo temporal, y se
presenta un análisis en el panel Resumen. Los campos cuyos datos se puedan clasificar como una dimensión o
medida pueden cambiar la vista previa para mostrarlos como una dimensión o medida. El modo en que se
clasifica un campo de datos en el panel Resumen no afecta a cómo se puede utilizar en las visualizaciones de
Qlik Sense, sino que determina qué opciones de transformación están disponibles para el campo de datos en
otros paneles de perfiles de datos.

Un resumen de los datos utilizando el panel de perfil de datos Resumen.

El panel Resumen proporciona la siguiente información:

l Valores distintos: El número de valores distintos en el campo.


l Total valores:El número de valores en el campo.

Gestión de datos - Qlik Sense, June 2019 73


3   Administrar los datos de la app con el Gestor de datos

l Vista previa de distribución de valores distintos: En campos con más de 20 valores distintos, solo
se muestran los 20 valores distintos con el recuento más alto. Todos los demás valores se agrupan en un
solo valor en el gráfico. Si todos los valores son distintos, no se mostrará ningún gráfico de barras.
l Rango de valores: (Solo Medidas y Temporal) Para un campo de medida, el Rango de valores es un
gráfico que muestra los valores Mín., Mediana, Media y Máx. del campo. Para un campo temporal, el
Rango de valores es el período de tiempo cubierto por los datos del campo.
l Valores nulos: El número de valores nulos en los datos. Esta visualización solo muestra si hay valores
nulos en el campo.
l Valores mixtos:El número de valores de texto en un campo que contiene valores de texto y numéricos.
Esta visualización solo muestra si hay valores mixtos en el campo.

Dependiendo de cómo se clasifique un campo en el panel Resumen, se puede modificar en otros paneles de
perfiles de datos. Los campos configurados como medidas pueden tener valores agrupados creados desde el
campo utilizando el panel Cubo. Para más información, vea Agrupar datos de medidas en rangos (page 81).

Los campos definidos como dimensiones pueden tener:

l Valores distintos reemplazados por otro valor usando el panel Reemplazar.


Para más información, vea Reemplazar valores de campo en una tabla (page 75).
l Valores distintos definidos como valores nulos utilizando la etiqueta Definir nulos.
Para más información, vea Definir valores de campo como nulos en una tabla (page 76).
l Un orden personalizado aplicado a los valores utilizando el panel Orden.
Para más información, vea Personalizar el orden de los valores de dimensión (page 77).
l Datos de campos divididos en nuevos campos de tabla utilizando el panel Dividir.
Para más información, vea Dividir un campo en una tabla (page 78).

Acceder al panel Resumen


Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo de tabla.

Aparece el panel Resumen.

Cambiar la categoría de datos de un campo


Qlik Sense permite cambiar el tipo de datos de un campo, siempre y cuando los datos del campo se puedan
clasificar en múltiples categorías.

Haga lo siguiente:

l En el panel Resumen, haga clic en S y seleccione una categoría diferente de datos.

Gestión de datos - Qlik Sense, June 2019 74


3   Administrar los datos de la app con el Gestor de datos

Reemplazar valores de campo en una tabla


El panel Reemplazar le permite reemplazar diferentes valores de campo en sus tablas por otros valores. En un
conjunto de datos, se pueden utilizar diferentes términos para el mismo objeto o concepto. Por ejemplo, el
nombre completo de un país y su abreviatura pueden encontrarse en el mismo conjunto de datos. El panel
Reemplazar le permite asegurarse de que estas instancias se traten como un solo valor distinto en lugar de
diferentes valores distintos. Por ejemplo, en un campo que contiene datos de país, puede reemplazar U.S, US y
U.S.A por USA. También puede utilizar el panel Reemplazar para cambiar valores individuales, como cuando es
necesario cambiar un nombre en un conjunto de datos.

Puede establecer valores de reemplazo en campos que contengan hasta un máximo de 5.000 valores distintos.

Además, los campos calculados ignoran los valores de reemplazo y usarán los valores originales en su lugar.

El panel Reemplazar consta de dos secciones: Valores distintos y Valor de reemplazo. Valores distintos
enumera todos los valores distintos y cualquier valor de reemplazo. Valor de reemplazo contiene un campo
para introducir el término de reemplazo y una lista de valores seleccionados para ser reemplazados. Los valores
de campo se reemplazan seleccionando valores distintos, introduciendo el valor de reemplazo y aplicando la
sustitución. También puede seleccionar un valor de reemplazo en Valores distintos y editarlo para cambiar los
valores que se están reemplazando o el valor que se utiliza para la sustitución. Puede agregar o editar múltiples
valores de reemplazo antes de aplicar los reemplazos.

Reemplazar valores
Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo de dimensión.
3. En el panel de perfiles de datos, haga clic en la pestaña Reemplazar.
4. En Valores distintos, seleccione los valores distintos que desee reemplazar.
5. En Valor de reemplazo, introduzca el nuevo valor para estos valores distintos.
6. Haga clic en Reemplazar.

Editar un valor de reemplazo


Puede añadir más valores distintos a un valor de reemplazo, eliminar valores distintos de un valor de reemplazo
o cambiar el valor de reemplazo.

Añadir valores distintos a un valor de reemplazo


Haga lo siguiente:

1. En el panel Reemplazar, bajo Valores distintos, seleccione un valor de reemplazo.


2. En Valores distintos, seleccione los valores distintos que desee añadir.
3. Haga clic en Reemplazar.

Eliminar valores distintos de un valor de reemplazo


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 75


3   Administrar los datos de la app con el Gestor de datos

1. En el panel Reemplazar, bajo Valores distintos, seleccione un valor de reemplazo.


2. Después de cada valor distinto que desee eliminar, haga clic en E .
3. Haga clic en Reemplazar.

Cambiar un valor de reemplazo


Haga lo siguiente:

1. En el panel Reemplazar, bajo Valores distintos, seleccione un valor de reemplazo.


2. En Reemplazo, introduzca un nuevo valor.
3. Haga clic en Reemplazar.

Eliminar un valor de reemplazo


Los valores de reemplazo se pueden eliminar eliminando todos los valores distintos asociados.

Haga lo siguiente:

1. En el panel Reemplazar, bajo Valores distintos, seleccione un valor de reemplazo.


2. Haga clic en Eliminar todos.
3. Haga clic en Reemplazar.

Definir valores de campo como nulos en una tabla


En el panel Definir nulos, seleccione determinados valores distintos desde un campo de dimensión para que
Qlik Sense los trate como valores nulos. Por ejemplo, si sus datos de origen incluyen representaciones como X
para valores nulos, puede utilizar el panel Definir nulos para especificar que ese valor sea tratado como un
valor nulo en Qlik Sense. Si su tabla contiene campos con espacios vacíos, puede definirlos como valores nulos
usando el panel Definir nulos. También puede utilizar el panel Definir nulos para limpiar los datos de valores
que no desee, definiendo esos valores no deseados como nulos.

Si desea utilizar un valor específico como su valor nulo, puede reemplazar el valor nulo predeterminado, -
(Null) , usando el panel Reemplazar. Para más información, vea Reemplazar valores de campo en una tabla
(page 75).

Puede establecer valores de campo como nulos en campos que contengan hasta un máximo de 5.000 valores
distintos.

El panel Definir nulos se compone de dos secciones: Valores distintos y Valores nulos fijados
manualmente. Cuando se seleccionan valores de Valores distintos, estos se agregan a Valores nulos fijados
manualmente. Cuando se aplican los valores nulos, todas las instancias de los valores seleccionados se
configuran como nulos en los datos del campo. Puede restaurar valores individuales o todos los valores
definidos como nulos.

Definir valores de campo como nulos


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 76


3   Administrar los datos de la app con el Gestor de datos

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo.
3. En el panel de perfiles de datos, haga clic en la pestaña Definir nulos.
4. En Valores distintos, seleccione los valores que desee definir como nulos.
5. Haga clic en Definir valores nulos.

Restaurar valores definidos manualmente como nulos


Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo.
3. En el panel de perfiles de datos, haga clic en la pestaña Definir nulos.
4. En el panel Definir nulos, bajo Valores nulos fijados manualmente, haga una de las siguientes
acciones:
l Haga clic en E después de los valores que ya no desee definir como nulos.
l Haga clic en Eliminar todos para restaurar todos los valores definidos como nulos.
5. Haga clic en Definir valores nulos.

Personalizar el orden de los valores de dimensión


El orden personalizado le permite establecer el orden de los valores de dimensión en las visualizaciones.
Mientras que el orden alfabético o numérico pueden funcionar para muchas visualizaciones, en algunos casos
es útil un orden alternativo. Por ejemplo, en un campo que contenga ciudades, podría establecer un orden
personalizado de modo que en sus gráficos las ciudades se muestren por un orden de este a oeste. Puede definir
un orden personalizado para campos que cumplan los siguientes requisitos:

l Los campos deben definirse como dimensiones en el panel Resumen.


l Los campos deben contener hasta un máximo de 5.000 valores distintos.
Se recomienda que su campo tenga un máximo de 25 valores, pero puede optar por usar el panel Orden
con campos que contengan hasta 5.000 valores distintos.

El panel Orden consta de dos secciones: Orden actual y Vista previa del orden. Orden actual muestra
todos los valores distintos de la dimensión. De forma predeterminada, los valores distintos se organizan por
orden de carga. Puede configurar su orden personalizado arrastrando los valores de Orden actual al orden
que desee. La Vista previa del orden es un gráfico de barras que muestra un recuento de valores de cada
valor distinto, organizado por el orden actual.

Un orden personalizado anula cualquier otra opción de clasificación disponible en las visualizaciones de Qlik
Sense, excepto para ordenar por orden de carga. Si necesita un orden alfabético o numérico para este campo,
debe eliminar el orden personalizado restableciendo el orden.

Cambiar el orden de los valores en un campo de dimensión


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 77


3   Administrar los datos de la app con el Gestor de datos

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo de dimensión.
3. En el panel de perfiles de datos, haga clic en la pestaña Orden.
4. Haga clic y arrastre los valores al nuevo orden.
5. Si desea cancelar el orden actual, haga clic en Cancelar.

Cancelar solo está disponible para nuevos órdenes personalizados. Para cancelar los
cambios, si está cambiando el orden de valores de un determinado orden personalizado
existente, seleccione un campo distinto de la tabla y después vuelva a seleccionar este
campo de nuevo.

6. Haga clic en Reordenar.

Restablecer el orden de los valores en un campo de dimensión


Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo de dimensión reordenado.
3. En el panel de perfiles de datos, haga clic en la pestaña Orden.
4. Haga clic en Restablecer.
5. Haga clic en Aceptar.

Dividir un campo en una tabla


El panel Dividir le permite crear nuevos campos utilizando datos de un campo ya existente. Podría, por
ejemplo, dividir un campo que contenga una dirección para crear un nuevo campo que contenga solo el código
postal. Esto le permite crear rápidamente nuevos campos que contengan segmentos relevantes de los datos. El
panel Dividir puede crear nuevos campos a partir de campos de tabla que satisfagan los requisitos siguientes:

l Los campos deben definirse como dimensiones en la etiqueta Resumen.

Los campos de tabla que contienen información de fecha y hora se dividen automáticamente en
campos de fecha cuando sus tablas se preparan en el Gestor de datos y no requieren el panel
Dividir.

El panel Dividir consta de un campo de entrada que contiene un valor de plantilla y una vista previa de los
nuevos campos con sus valores. De forma predeterminada, el valor de la plantilla es el primer valor por orden
numérico de un campo, pero puede seleccionar otros valores del campo de origen para utilizarlos como
plantilla. Debe seleccionar un valor que sea representativo de todos los valores de la tabla. La división utilizando
un valor atípico como plantilla puede afectar a la calidad de los nuevos campos.

Gestión de datos - Qlik Sense, June 2019 78


3   Administrar los datos de la app con el Gestor de datos

Los campos se dividen insertando marcadores de división en el valor de plantilla en el que desee dividir el
campo. Los marcadores de división se añaden seleccionando un punto en el campo de muestra al que se desee
agregar un marcador dividido, ajustando su selección y después seleccionando dividir por instancia o posición.
El panel Dividir puede agregar automáticamente los marcadores de división recomendados a su valor de
plantilla.

Las instancias son ejemplos de un delimitador seleccionado, como el carácter @ o un espacio entre palabras.
Las posiciones de los marcadores de división de instancias son relativas a uno de los siguientes:

l El inicio del valor, como la primera instancia de @ en un valor.


l Su posición a la derecha de otra instancia o marcador de división de posición, como la primera
instancia de . después de @.

Si elimina la instancia a la que se refiere otra instancia, la posición de la otra instancia se ajusta a la misma
posición con respecto a la siguiente instancia de un conjunto delimitador diferente como marcador de división o
el inicio del valor. Puede dividir un campo hasta en 9 delimitadores.

La tarjeta Dividir divide los valores utilizando los caracteres especificados como marcadores de
división. Si los datos presentan variaciones en la forma de estos caracteres, como por ejemplo
caracteres acentuados, estas diferencias no se incluirán en la división.

Las posiciones son ubicaciones en el valor de campo, por ejemplo, tras los primeros cuatro caracteres. Las
posiciones son relativas a uno de los siguientes:

l El inicio del valor.


l Su posición a la derecha de un marcador de división de instancia, como por ejemplo el segundo carácter
tras un marcador de división de instancia.

Si ha eliminado una instancia que tiene una posición a su derecha, la posición se mueve a la misma posición
con respecto al inicio del valor o al primer marcador de división de la instancia a la izquierda o al inicio del
valor.

La vista previa del campo se actualiza a medida que agrega marcadores de división, mostrando los nuevos
campos y sus datos. Puede cambiar el nombre de los nuevos campos en la vista previa del campo. También
puede seleccionar incluir o excluir los campos divididos de su tabla antes de aplicar la división. Cuando aplique
una división, los campos seleccionados en la vista previa de campo se agregan a su tabla.

Un campo se puede dividir múltiples veces.

Para dividir un campo en nuevos campos, haga lo siguiente:

1. Acceda al panel División.


2. Defina los marcadores de división en el campo de entrada.
3. También puede realizar las siguientes tareas opcionales:
l Eliminar los marcadores de división
l Seleccionar qué campos nuevos desea agregar a la tabla.

Gestión de datos - Qlik Sense, June 2019 79


3   Administrar los datos de la app con el Gestor de datos

l Renombrar los nuevos campos.


4. Cree los nuevos campos.

Acceder al panel de división


Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Seleccione un campo de dimensión.
3. En el panel de perfiles de datos, haga clic en la pestaña Dividir.

Insertar marcadores de división


Los marcadores de división se insertan haciendo clic en las posiciones del valor de muestra y seleccionando el
tipo de división que desee aplicar.

Puede cambiar el valor de muestra que se muestra en el campo de entrada haciendo clic en S y
seleccionando un valor diferente.

Haga lo siguiente:

1. En el panel de División, haga clic en la posición del valor de muestra en el que desee agregar
marcadores de división.
Al hacer clic, se selecciona todo el valor de la plantilla hasta cualquier otro marcador de división.
Al hacer doble clic, se selecciona el punto de inserción del cursor en el valor de la plantilla.
2. Ajuste su selección haciendo clic y arrastrando las pestañas de selección o resaltando la sección que
desee seleccionar.
3. Haga clic en el botón que corresponde al tipo de división que desea aplicar:
l Esta instancia: El campo se divide por la instancia seleccionada del delimitador.
l Todas las instancias: El campo se divide por todas las instancias del delimitador.
l Estas posiciones:El campo se divide en cualquiera de ambos lados de la selección.
l Esta posición: El campo se divide en esta posición.

El marcador de división se inserta en el valor de muestra.

Eliminar marcadores de división


Haga lo siguiente:

l En el panel Dividir, realice una de las siguientes acciones:


l Para eliminar un único marcador de división, haga clic en E encima del marcador de división
que desee eliminar.
l Para eliminar todos los marcadores de división, haga clic en Restablecer.
Los marcadores de división recomendados no se eliminarán y cualquier marcador de división
recomendado eliminado se agregará de nuevo a la plantilla. Debe eliminar estos
individualmente.

Gestión de datos - Qlik Sense, June 2019 80


3   Administrar los datos de la app con el Gestor de datos

Seleccionar los campos que añadir a su tabla


Puede seleccionar qué campos creados por el panel Dividir incluir o excluir de su tabla. De forma
predeterminada, se incluyen todos los campos divididos.

Haga lo siguiente:

l En el panel Dividir, en la vista previa del campo, realice una de las siguientes acciones:
l Para incluir un campo, seleccione la casilla de verificación de la columna de campo.
l Para excluir un campo, desactive la casilla de verificación de la columna de campo.

Renombrar nuevos campos


Haga lo siguiente:

l En el panel Dividir, en un encabezado de campo en la vista previa del campo, introduzca un nuevo
nombre de campo.

Crear nuevos campos


Haga lo siguiente:

l En el panel Dividir, haga clic en Dividir.

Agrupar datos de medidas en rangos


Las medidas pueden proporcionar una visión adicional de cara al análisis cuando se agrupan en rangos y se
utilizan como dimensiones en las visualizaciones. Por ejemplo, si un campo tenía edades de clientes, podríamos
agrupar los valores en rangos de edad. El panel de perfiles de datos Cubo permite agrupar los datos de campos
en rangos, creando un nuevo campo con los agrupamientos especificados. Puede acceder al panel de perfiles de
datos Cubo editando una tabla en el Gestor de datos y seleccionando un campo de tabla que esté definido
como medida en el panel Resumen. Puede agrupar las medidas en distintos rangos con campos que cumplan
los siguientes requisitos:

l Los campos deben definirse como dimensiones en el panel Resumen.


l Los campos deben contener al menos 10 valores distintos.
El panel Cubo no se recomienda con campos que contengan un bajo rango de valores, pero puede
elegir usar el panel Cubo con campos no recomendados.
l Los valores del campo no pueden contener más de un 20% de tipos mixtos.
El panel Cubo no se recomienda con campos que contengan tipos mixtos de valores, pero puede elegir
usar el panel Cubo con campos no recomendados.

Los campos cubo creados con el panel Cubo se clasifican como dimensiones en el panel Resumen.
Sin embargo, no se puede aplicar un orden personalizado a los campos cubo usando el panel
Orden. Los campos cubo no se pueden utilizar en campos calculados.

Gestión de datos - Qlik Sense, June 2019 81


3   Administrar los datos de la app con el Gestor de datos

El panel Cubo ofrece un número sugerido de agrupaciones, una vista previa de los agrupamientos y una barra
deslizante que contiene sus agrupaciones y que permite modificar el nombre de cada cubo y el rango de
valores. Puede modificar el número sugerido de agrupaciones introduciendo un nuevo número en el campo
Cubo. Qlik Sense admite un máximo de 20 cubos y un mínimo de 2 cubos. Los nuevos cubos se añaden a la
derecha de su rango de cubos, mientras que los cubos se eliminan de derecha a izquierda. Si no ha modificado
ningún cubo individual, el rango de cada cubo se ajusta para que se adapte de forma uniforme al rango de
valores del campo. Si cambia el número de cubos después de haber modificado un cubo individual, se añaden
nuevos cubos a la derecha de su rango de cubo y se les asigna un rango de valores igual al tamaño del segundo
cubo situado más a la derecha.

El gráfico de barras Vista previa de los cubos de datos muestra una panorámica de los datos que hay en los
cubos, con un recuento del número de valores distintos en cada cubo. El gráfico se va actualizando a medida
que cambia sus cubos. Si un cubo no contiene ningún valor, no habrá una barra en el gráfico.

La barra deslizante Cubo le permite editar sus cubos. Al hacer clic en un segmento de cubo, puede definir el
rango de dicho cubo, cambiar el nombre del cubo o eliminar el cubo por completo. Colocar el cursor sobre el
cubo muestra el nombre y el rango de valores del cubo. De forma predeterminada, los cubos se denominan
conforme al rango de valores del cubo expresado como una notación de intervalo. Los rangos de los cubos
incluyen valores entre el valor inicial y hasta, pero sin incluirlo, el valor final.

Al ajustar el rango de valores de un solo cubo, Qlik Sense cambia los valores de todos los cubos, asegurando que
no haya lagunas y solapamientos y respetando al mismo tiempo lo más posible los rangos cuantitativos de los
otros cubos. El cubo situado más a la izquierda nunca tiene límite inferior y el cubo situado más a la derecha
nunca tiene límite superior. Esto les permite capturar cualquier valor que pueda caer fuera de los rangos
establecidos en todos sus cubos. La modificación del rango inferior de un cubo alterará los rangos de los cubos
situados a la derecha, la modificación del rango superior de un cubo modificará los cubos situados a la
izquierda.

Cuando se crean cubos desde un campo, se genera un nuevo campo que contiene todos los cubos asignados a
las filas con sus correspondientes valores de medida del campo de origen. De forma predeterminada, se llamará
<field> (En cubos). Este campo puede renombrarse, asociarse, ordenarse y eliminarse, como otros campos de
tabla. Puede editar el esquema de cubo en el campo de cubo generado seleccionando el campo de la tabla y
modificando las opciones de cubos. Puede crear varios campos de cubo desde el mismo campo de medida de
origen.

Para agrupar valores de medida en rangos, haga lo siguiente:

1. Acceda al panel Cubo.


2. Opcionalmente, cambie el número de cubos.
3. Opcionalmente, modifique los cubos individuales.
4. Opcionalmente, restablezca los ajustes manuales de los cubos a los ajustes predeterminados.
5. Cree el campo de cubos.

Acceder al panel Cubos


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 82


3   Administrar los datos de la app con el Gestor de datos

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Si está creando nuevos grupos de rangos de valores, seleccione un campo.
3. Si está editando un campo de cubos existente, seleccione un campo de cubos.

Cambiar el número de cubos


Cambiar el número de cubos añade cubos o elimina los cubos del extremo del rango.

Haga lo siguiente:

l En el panel Cubo, introduzca un nuevo número antes de Cubos.

Modificar un cubo
Puede cambiar el nombre de un cubo, ajustar el rango de valores de un cubo o eliminar un cubo.

Si está modificando cubos, se recomienda modificar los cubos por orden, desde el segmento de
cubo situado más a la izquierda hasta el segmento de cubo situado más a la derecha.

Cambiar el nombre de un cubo


Haga lo siguiente:

1. En el panel Cubo, haga clic en el segmento de cubo.


2. En el campo de nombre, escriba un nuevo nombre.
3. Para aplicar sus cambios, haga clic en cualquier lugar fuera del segmento de cubo.

Ajustar el rango de valores de un cubo

Si está tratando de usar valores decimales, debe introducirlos manualmente en los campos Desde y
Hasta.

Haga lo siguiente:

1. En el panel Cubo, haga clic en el segmento de cubo.


2. Puede realizar una de las acciones siguientes:
l Detrás de Desde y Hasta, introduzca nuevos valores para establecer el rango del cubo.
Un cubo incluye los valores comprendidos entre el valor que figura en Desde y hasta pero
excluyendo el valor contenido en Hasta.
l Ajuste los deslizadores del segmento para definir el rango del cubo.
3. Para aplicar sus cambios, haga clic en cualquier lugar fuera del segmento de cubo.

Eliminar un cubo
Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 83


3   Administrar los datos de la app con el Gestor de datos

1. En el panel Cubo, haga clic en el segmento del cubo.


2. Haga clic en Ö .

Restablecer los cubos de un campo


El restablecimiento de los cubos le permite restaurar la configuración de los paneles de cubo a su estado
predeterminado. Si se trata de un campo de medida, el estado predeterminado es el esquema de cubo
recomendado por Qlik Sense. Si se trata de un campo de cubo, el estado predeterminado es el estado que tenía
el campo tras la última vez que se hizo clic en Crear cubos.

Haga lo siguiente:

l En el panel Cubo, haga clic en Restablecer valores predeterminados.

Crear un campo de cubo


Haga lo siguiente:

1. En el panel Cubo, haga clic en Crear cubos.


2. Haga clic en Aceptar.

El nuevo campo que contiene su agrupación de datos se añade a su tabla.

Despivotar datos de una tabla cruzada en el gestor de datos


Una tabla cruzada es un tipo habitual de tabla, que ofrece una matriz de valores entre dos listas ortogonales de
datos de cabecera. Por lo general no es el formato de datos más óptimo si queremos asociar los datos con otras
tablas de datos. Esta sección describe cómo podemos despivotar datos cargados en un formato de tabla
cruzada, esto es, transponer (o trasladar) partes del mismo a filas utilizando el gestor de datos.

Despivotar datos cargados en formato de tabla cruzada traslada partes de la misma a filas.

¿Qué es una tabla cruzada?


Una tabla cruzada contiene una serie de columnas cualificadoras, las cuales deben leerse de una determinada
manera, y una matriz de valores. En este caso hay una columna de calificación, Year, y una matriz de datos de
ventas por mes.

Gestión de datos - Qlik Sense, June 2019 84


3   Administrar los datos de la app con el Gestor de datos

Crosstab
Year Jan Feb Mar Apr May Jun

2008 45 65 78 12 78 22

2009 11 23 22 22 45 85

2010 65 56 22 79 12 56

2011 45 24 32 78 55 15

2012 45 56 35 78 68 82

Si esta tabla simplemente se carga en Qlik Sense el resultado será una tabla con un campo por Year y otro
campo por cada uno de los meses. Por regla general, éste no es el resultado que interesa. Probablemente
preferiríamos tener tres campos generados:

l El campo cualificador, en este caso Year , marcado con verde en la tabla superior.
l El campo de atributo, en este caso representado por los nombres de mes Jan - Jun marcados con
amarillo. Este campo se puede denominar de forma adecuada Month.
l El campo de datos, marcado en azul. En este caso representan datos de ventas, por lo que pueden
nombrarse Sales de forma adecuada.

Esto se puede lograr usando la opción Despivotar en el editor de tablas del gestor de datos y seleccionando los
campos Jan - Jun. Esto crea la tabla siguiente:

Tabla despivotada
Year Month Sales

2008 Ene 45

2008 Feb 65

2008 Mar 78

2008 Abr 12

2008 May 78

2008 Jun 22

2009 Ene 11

2009 Feb 23

... ... ...

Despivotar una tabla cruzada para tener una tabla plana


Haga lo siguiente:

1. Añada un archivo de datos con un formato de tabla cruzada a su app.


2. Haga clic en @ en la tabla en el gestor de datos para abrir el editor de tabla.

Gestión de datos - Qlik Sense, June 2019 85


3   Administrar los datos de la app con el Gestor de datos

3. Haga clic en Despivotar.


4. Seleccione los campos que desee transponer en filas. Es necesario tener al menos un campo cualificador
que no esté despivotado. Hay dos maneras de hacer las selecciones.
l Haga clic en las cabeceras de los campos que desee transponer. No seleccione los campos que
desee mantener como campos cualificadores.
l Haga clic en las cabeceras de los campos que desee mantener como campos cualificadores y
después seleccione Invertir selecciones en el menú de campo. Esta es la forma más fácil de
hacerlo si tiene un gran número de campos que transponer.
5. Haga clic en Aplicar despivotar
Los datos seleccionados ahora se transponen a dos campos, Tablename.Campo de atributo y
Tablename.Campo de datos.
6. Renombre Campo de atributo a algo lógico, en el ejemplo anterior, Month.
7. Renombre Campo de datos a algo lógico, en el ejemplo anterior, Sales.

Ahora ha despivotado la tabla cruzada a un formato plano, lo que hará que sea más fácil de asociar a otros
datos en la app.

Revertir el formato a la tabla cruzada original


Puede volver al formato original de tabla cruzada de su fuente de datos haciendo clic en Deshacer despivotar
en el editor de tabla. Si ha creado alguna asociación a otros datos en la app, se eliminarán las asociaciones.

3.13 Concatenar tablas en el Gestor de datos


La concatenación combina dos tablas en una sola tabla con campos combinados. Consolida el contenido,
reduciendo así el número de tablas y campos que comparten contenido. Las tablas del Gestor de datos se
pueden concatenar automáticamente o de manera forzada.

Tabla concatenada en la vista de Tablas y en la vista de Asociaciones.

Concatenar tablas automáticamente


Las tablas se concatenan automáticamente en el Gestor de datos cuando Qlik Sense detecta que una o más
tablas añadidas tienen el mismo número de campos e idénticos nombres de campos que otra tabla. Cuando
esto ocurre, Qlik Sense concatena las tablas automáticamente en una sola tabla. Las tablas concatenadas
automáticamente se pueden dividir si se concatenaron de forma errónea o si no las quiere concatenadas. Las
tablas concatenadas automáticamente se pueden concatenar de manera forzada con otras tablas.

Gestión de datos - Qlik Sense, June 2019 86


3   Administrar los datos de la app con el Gestor de datos

Las tablas concatenadas automáticamente tienen las siguientes restricciones:

l No se pueden cambiar las categorías de campos.


l No se puede despivotar una tabla concatenada automáticamente.
l No puede añadir ni eliminar datos con Seleccionar datos de fuente.

Forzar la concatenación entre tablas


Se puede forzar la concatenación entre tablas en el Gestor de datos utilizando el panel Concatenar tablas,
aunque no compartan por completo los mismos campos o datos. La concatenación forzada le permite
controlar las correspondencias y excluir campos de la tabla final concatenada. La concatenación forzada
admite transformaciones adicionales. Utilizando la concatenación forzada, se puede:

l Concatenar una tabla concatenada con otra tabla.


l Concatenar una tabla no pivotada con otra tabla. Las tablas concatenadas de manera forzada se
pueden despivotar.
l Concatenar tablas con campos calculados. Los campos calculados se pueden concatenar con otros
campos en una concatenación forzada. Los campos calculados se pueden agregar a las tablas
concatenadas de manera forzada.

Las tablas concatenadas de manera forzada tienen las siguientes restricciones:

l La concatenación forzada requiere que al menos un campo de cada tabla se incluya en la tabla
concatenada, aunque no es necesario asociarlos (mapearlos).
l Los campos de fecha no pueden formatearse tras la concatenación. Los campos de fecha deben tener el
mismo formato aplicado a todos antes de la concatenación. Los campos de fecha concatenados utilizan
el formato de hora predeterminado configurado con DateFormat en el Editor de carga de datos.
l No se pueden cambiar las categorías de campos tras la concatenación.
l Los campos calculados que hacen referencia a un campo asociado con otro campo en una tabla
concatenada solo contendrán datos para el campo original en lugar de los datos combinados en el
campo concatenado. Los campos calculados creados después de concatenar dos tablas que se refieren a
un campo de la tabla concatenada utilizarán todos los datos de ese campo.
l No puede añadir ni eliminar datos de una tabla concatenada con Seleccionar datos de fuente. Sí
puede, no obstante, eliminar campos haciendo clic en Añadir datos, seleccionando la tabla de origen y,
a continuación, excluyendo los campos. Se agregan valores nulos para los datos del campo eliminado.

Al panel de Concatenar tablas se accede haciendo clic en ¥ en el Gestor de datos, haciendo clic en
Concatenar tablas y seleccionando dos tablas. Cuando se seleccionan tablas en Concatenar tablas, Qlik
Sense analiza los campos y automáticamente asocia todos los campos que coincidan. Si no hay
correspondencias claras, los campos quedan sin asociar. Cuando se aplica la concatenación, los campos
asociados se combinan en la tabla concatenada, mientras que los campos no asociados se incluyen como
campos individuales con valores nulos para las filas donde no hay ningún valor correspondiente.

La primera tabla seleccionada en Concatenar tablas se define como la tabla principal, la tabla a la que se
concatena la otra tabla. La tabla concatenada utiliza los nombres de tabla y campo de la tabla principal, a
menos que se modifique su nombre manualmente. Puede cambiar qué tabla es la tabla principal con el botón

Gestión de datos - Qlik Sense, June 2019 87


3   Administrar los datos de la app con el Gestor de datos

♫ . Concatenar tablas organiza los campos en dos filas, con los campos de la tabla principal en la fila
superior y los campos de la tabla secundaria en la fila inferior. Puede intercambiar las tablas primarias y
secundarias con el botón ♫ .

Puede utilizar Editar correspondencias para cambiar la asociación predeterminada y seleccionar qué
campos asociar, dejar sin asociar o excluir de la tabla concatenada. Editar correspondencias contiene una
interfaz de arrastrar y soltar para editar asociaciones y el panel Campos, que enumera todos los campos de
tabla. Los campos se pueden asociar arrastrándolos debajo de un campo de la tabla principal. Se pueden
agregar campos como un nuevo campo sin asignar mediante ∑ al lado del campo en el panel Campos o
arrastrándolos a la fila superior de campos. Los campos sin asignar van marcados con ù en el panel
Campos. Los campos eliminados de la tabla concatenada no se incluyen en la tabla y no están disponibles para
su uso en Qlik Sense después de haber aplicado la concatenación a la tabla.

Una vez que se apliquen las correspondencias o asociaciones y se concatenen las tablas, estas no se pueden
editar, pero se pueden eliminar de las tablas mediante la división de la tabla concatenada, lo cual restaura las
tablas a su estado original.

Para concatenar tablas de manera forzada en el Gestor de datos, haga lo siguiente:

1. Seleccione las tablas para la concatenación.


2. Si lo desea puede cambiar el nombre de la tabla concatenada y los nombres de campo.
3. Si lo desea, edite las correspondencias (asociaciones) de la concatenación.
4. Concatene las tablas.

Seleccionar las tablas para la concatenación


Haga lo siguiente:

1. En el Gestor de datos, haga clic en ¥ en la fila inferior.


2. Haga clic en Concatenar tablas.
Se abre el panel Concatenar tablas.
3. Seleccione dos tablas.
Los campos de ambas tablas se asociarán o quedarán sin asociar en el panel Concatenar tablas.
4. Para previsualizar una muestra de valores únicos en cada campo, haga clic en † .
5. Para cambiar las tablas primaria y secundaria, haga clic en ♫ .

Cambiar los nombres de tabla y campos


Haga lo siguiente:

1. En el panel Concatenar tablas, en el campo de nombre de tabla, escriba un nuevo nombre de tabla.
2. En un campo de nombre de campo, escriba un nuevo nombre de campo.

Editar las correspondencias de concatenación


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 88


3   Administrar los datos de la app con el Gestor de datos

1. En el panel Concatenar tablas, haga clic en Editar correspondencias.


2. Para asociar dos campos, haga clic y arrastre un campo de la tabla bajo un campo de la tabla principal.
3. Para añadir un nuevo campo no asociado, haga clic y arrastre un campo de tabla a la fila superior de
campos.
4. Para eliminar un campo de la tabla concatenada, en el campo haga clic en E .
5. Para devolver un campo eliminado a la tabla, haga clic en el panel Campos y haga clic en ∑ junto al
campo.
6. Haga clic en Editar correspondencias para cerrar Editar correspondencias.

Concatenar tablas
Haga lo siguiente:

l En el panel Concatenar tablas, haga clic en Aplicar.

Las tablas están ahora concatenadas.

Dividir tablas concatenadas


En los casos en que ya no es necesaria la concatenación, por ejemplo, cuando Qlik Sense ha realizado una
concatenación automática no deseada, puede dividir las tablas concatenadas en sus tablas de origen.

Dividir una tabla concatenada eliminará cualquier asociación que la tabla concatenada tenía, así
como cualquier asociación que las tablas primaria y secundaria tenían entre sí. Si desea conservar
sus asociaciones mientras divide las tablas concatenadas, haga clic en B para deshacer la
concatenación en lugar de dividir la tabla. No puede usar B para deshacer la concatenación tras
haber cargado los datos en el Gestor de datos.

Dividir una tabla concatenada automáticamente


Haga lo siguiente:

1. Seleccione la tabla concatenada.


2. Haga clic en → .
3. Seleccione las tablas que hay que dividir de la tabla concatenada.
4. Haga clic en Dividir.

La tabla se divide ahora en sus tablas de origen y todos los campos de las tablas de origen están calificados. Los
campos calificados se renombran con el nombre de la tabla seguido del nombre del campo, separados por un
signo de puntuación (el carácter ".").

Example:

Table1 y Table2 ambas contienen los campos Field1 y Field2. Cuando las añade en el Gestor de datos, se
concatenan con una tabla denominada Table1-Table2 con los mismos campos, Field1 y Field2.

Si divide Table1-Table2, el resultado son dos tablas:

Gestión de datos - Qlik Sense, June 2019 89


3   Administrar los datos de la app con el Gestor de datos

l Table1 con campos Table1.Field1 y Table1.Field2


l Table2 con campos Table2.Field1 y Table2.Field2

Dividir una tabla concatenada de manera forzada


Haga lo siguiente:

1. Seleccione la tabla concatenada.


2. Haga clic en → .

La tabla se ha dividido ahora en sus tablas de origen. Todos los campos de las tablas de origen y sus campos
tienen los nombres que tenían antes de la concatenación. Dividir una tabla concatenada solo divide un nivel de
concatenación, de modo que cualquier tabla concatenada que formara parte de la tabla concatenada dividida
conservará su propia concatenación.

3.14 Ver los detalles de transformación de tablas y campos


en el Gestor de datos
Puede ver las operaciones y transformaciones realizadas en tablas y campos en el Gestor de datos utilizando
el diálogo Detalles. El diálogo Detalles está disponible en las vistas de Asociaciones y Tabla para las tablas y
en el editor de tabla de datos para los campos.

Detalles muestra las operaciones y las transformaciones actuales realizadas en la tabla o campo seleccionado,
en el orden en que se aplican en el script de carga de datos generado. Esto le permite ver con facilidad el origen
de una tabla o campo, los cambios actuales que se han realizado y la secuencia en la que se han aplicado los
cambios. Puede usar Detalles, por ejemplo, para ver fácilmente qué tablas se concatenaron o si se cambió el
orden de un campo.

La información que se muestra en Detalles varía según se esté viendo una tabla o un campo. Detalles de tabla
muestra:

l Las tablas de origen de la tabla seleccionada.


l Las transformaciones utilizadas en la tabla, como el despivotado y la concatenación.

Detalles de campo muestra:

l Las tablas y campos de origen del campo seleccionado.


l Los cambios en el tipo de campo.
l Las transformaciones realizadas en los campos, como aquellas efectuadas desde el panel de generación
de perfiles de datos o desde la concatenación.

Ver los detalles de tabla


Haga lo siguiente:

l En el Gestor de datos, seleccione una tabla, haga clic en ¥ y clic en Ver detalles.

Se abre el diálogo Detalles.

Gestión de datos - Qlik Sense, June 2019 90


3   Administrar los datos de la app con el Gestor de datos

Ver los detalles de campo


Haga lo siguiente:

1. En el Gestor de datos, seleccione una tabla y haga clic en @ .


2. Haga clic en Ô sobre un encabezado de campo y haga clic en Ver detalles.

Se abre el diálogo Detalles.

3.15 Paso a paso: Combinar tablas usando concatenación


forzada
Esta guía paso a paso muestra cómo se puede usar la concatenación forzada para combinar dos tablas de
datos similares.

La concatenación forzada se puede usar para limpiar los datos antes de usarlos para el análisis en una hoja.
Puede concatenar dos tablas en una tabla. También puede agregar otra tabla más adelante, por ejemplo, si
inicialmente agrega una tabla de junio, y luego desea agregar una segunda tabla a partir de julio.

La concatenación de un vistazo
l Las tablas se concatenan automáticamente en el Gestor de datos cuando Qlik Sense detecta que una o
más tablas agregadas tienen ambas el mismo número de campos y nombres de campo idénticos a los
de otra tabla. En este caso, puede dividir las tablas si es necesario.
l Se puede obligar a concatenar dos tablas cuando las tablas no comparten por completo los mismos
campos o datos. Solo se puede obligar a concatenar dos tablas. Para concatenar tres tablas, por
ejemplo, concatene las dos primeras tablas en una tabla. Y después concatene la tercera tabla a esa
tabla creada.
l Las tablas que no sean lo suficientemente iguales no se concatenarán automáticamente. Tampoco
podrá concatenarlas a la fuerza. En este caso, los campos de la tabla deberían asociarse en el Gestor de
datos.

Guía paso a paso: Concatenación forzada


Aquí tiene las tareas requeridas para completar esta guía:

1. Preparar las tablas de datos


2. Añadir tablas de datos a una app
3. Concatenar y cargar tablas de datos en una app
4. Un paso más: agregar una nueva tabla y concatenar los campos de datos

Requisitos previos
Debe saber cómo crear una app en Qlik Sense.

Gestión de datos - Qlik Sense, June 2019 91


3   Administrar los datos de la app con el Gestor de datos

Preparar las tablas de datos


Proporcionamos algunos datos de muestra para que los utilice para demostrar la concatenación forzada.
También puede usar sus propios datos, siempre que los campos y los datos sean prácticamente los mismos en
sus dos tablas.

Por ejemplo, aquí tiene el encabezado y la primera fila de los datos que ofrecemos a continuación. Se han
pegado en dos tablas de Excel . Tenga en cuenta las diferencias en los campos.

If you want to use the sample data, copy the entire table, including the column headings, into an empty Excel file
on your computer. For this walkthrough, we named the Excel tabs Data Table 1 and DataTable 2. We named the
Excel file Concatenate_Data.xlsx.

Tabla de datos 1
Tabla de datos 1
Fecha de
SalesOrde SalesOrderDeta TrackingNum OrderQ PI SpecialOffe UnitPri
modificaci
rID ilID ber ty D rID ce
ón

43659 1 4911-403C-98 1 77 1 1822.494 7/1/2013


6 6 0:00

43659 2 4911-403C-98 3 77 1 1822.494 7/2/2013


7 6 0:00

43659 3 4911-403C-98 1 77 1 1098.9 7/2/2013


8 0:00

43659 4 4911-403C-98 1 77 1 1835.994 7/2/2013


1 6 0:00

43659 5 4911-403C-98 1 77 1 1835.994 7/3/2013


2 6 0:00

43659 6 4911-403C-98 2 77 1 1835.994 7/3/2013


3 6 0:00

43659 7 4911-403C-98 1 77 1 1835.994 7/4/2013


4 6 0:00

43659 8 4911-403C-98 3 71 1 25.95636 7/4/2013


4 0:00

Gestión de datos - Qlik Sense, June 2019 92


3   Administrar los datos de la app con el Gestor de datos

Fecha de
SalesOrde SalesOrderDeta TrackingNum OrderQ PI SpecialOffe UnitPri
modificaci
rID ilID ber ty D rID ce
ón

43659 9 4911-403C-98 1 71 1 25.95636 7/5/2013


6 0:00

43659 10 4911-403C-98 6 70 1 5.13 7/5/2013


9 0:00

43659 11 4911-403C-98 2 71 1 4.66785 7/6/2013


2 0:00

43659 12 4911-403C-98 4 71 1 18.16785 7/6/2013


1 0:00

43660 13 6431-4D57-83 1 76 1 377.5130 7/7/2013


2 1 0:00

43660 14 6431-4D57-83 1 75 1 787.3146 7/7/2013


8 0:00

43661 15 4E0A-4F89-AE 1 74 1 728.784 7/7/2013


5 0:00

43661 16 4E0A-4F89-AE 1 74 1 643.2338 7/8/2013


3 7 0:00

43661 17 4E0A-4F89-AE 2 74 1 643.2338 7/8/2013


7 7 0:00

43661 18 4E0A-4F89-AE 4 71 1 4.66785 7/8/2013


2 0:00

43661 19 4E0A-4F89-AE 4 71 1 25.95636 7/9/2013


5 0:00

Tabla de datos 2
Tabla de datos 2
Fecha de
SalesOrderI SalesOrderDetailI TrackingNumb OrderQt ProductI UnitPric
modificació
D D er y D e
n

43662 20 2E53-4802-85 3 764 377.51301 7/12/2013


0:00

43662 21 2E53-4802-85 5 770 377.51301 7/12/2013


0:00

43662 22 2E53-4802-85 2 730 165.54438 7/13/2013


0:00

Gestión de datos - Qlik Sense, June 2019 93


3   Administrar los datos de la app con el Gestor de datos

Fecha de
SalesOrderI SalesOrderDetailI TrackingNumb OrderQt ProductI UnitPric
modificació
D D er y D e
n

43662 23 2E53-4802-85 4 754 787.3146 7/14/2013


0:00

43662 24 2E53-4802-85 3 725 165.54438 7/14/2013


0:00

43662 25 2E53-4802-85 5 762 377.51301 7/14/2013


0:00

43662 26 2E53-4802-85 3 765 377.51301 7/14/2013


0:00

43662 27 2E53-4802-85 2 768 377.51301 7/15/2013


0:00

43662 28 2E53-4802-85 1 753 1932.2658 7/15/2013


0:00

43663 29 2E53-4802-85 1 756 787.3146 7/16/2013


0:00

43663 30 2E53-4802-85 3 763 377.51301 7/17/2013


0:00

43664 31 2E53-4802-85 1 732 321.2082 7/18/2013


0:00

43664 32 2E53-4802-85 6 758 787.3146 7/19/2013


0:00

43665 33 2E53-4802-85 1 729 165.54438 7/19/2013


0:00

Añadir tablas de datos a una app


Haga lo siguiente:

1. Inicie Qlik Sense.


2. Haga clic en Crear nueva app en su área de trabajo. Se abre la ventana Crear nueva app.
3. Dé un nombre a su app y después haga clic en Crear. La app se crea. Hemos denominado a nuestra app
ConcatenateExample
4. Haga clic en Abrir app. La app se abre y muestra un diálogo donde puede agregar datos.
5. Arrastre y suelte su archivo de Excel en el diálogo Añadir datos de archivos y otras fuentes. Sus
tablas se muestran en la vista Asociaciones del Gestor de datos. Haga clic en una burbuja para ver los
datos de esa tabla.

Gestión de datos - Qlik Sense, June 2019 94


3   Administrar los datos de la app con el Gestor de datos

Si en cambio agrega datos desde el Gestor de datos, primero se le pedirá que seleccione los
campos de la tabla antes de llevarlos a la vista Asociaciones del Gestor de datos. En este
caso, seleccione todos los campos para ambas tablas

Concatenar tablas y cargar tablas de datos en una app


Después de que las tablas de datos se hayan agregado a la app, las tablas se pueden concatenar.

Haga lo siguiente:

1. En la vista Asociaciones del Gestor de datos, seleccione una tabla haciendo clic en la burbuja. Haga
clic en ¥ y después seleccione Concatenar tablas.

Gestión de datos - Qlik Sense, June 2019 95


3   Administrar los datos de la app con el Gestor de datos

2. Haga clic en la burbuja de la otra tabla y luego haga clic en Editar correspondencias.

3. Ahora puede hacer lo siguiente según sea necesario:


i. En Nombre de tabla, renombre la tabla que se creará cuando combine las tablas.
ii. Combine los campos arrastrando y soltando las etiquetas de campo.
iii. Renombrar campos
iv. Elimine los campos haciendo clic en E para el campo.

Gestión de datos - Qlik Sense, June 2019 96


3   Administrar los datos de la app con el Gestor de datos

En nuestro ejemplo, hicimos lo siguiente:


i. Cambiamos el nombre de nuestra tabla a Tabla de datos
ii. Arrastramos la etiqueta y el campo ProductID debajo del campo PID, para combinar los campos.
iii. Cambiamos el nombre del campo PID a Product ID.
iv. Eliminamos el campo SpecialOfferID.
Nuestra tabla ahora presenta el siguiente aspecto:

4. Haga clic en Aplicar. Las tablas están concatenadas en los campos asignados. El * indica que los datos
aún no se han cargado en la app.

Gestión de datos - Qlik Sense, June 2019 97


3   Administrar los datos de la app con el Gestor de datos

5. Haga clic en Cargar datos. Se muestra un mensaje que indica que los datos se cargaron correctamente.
Haga clic en Editar hoja para crear visualizaciones usando los datos.

Un paso más: agregar una nueva tabla y concatenar los campos de


datos
Los datos de muestra proporcionados anteriormente se pegaron en dos pestañas en el mismo archivo de Excel.
No obstante, las tablas no tienen que estar en el mismo archivo cuando deseamos concatenar campos. Las
tablas pueden estar en archivos aparte que se agregan a la app. También puede agregar otra tabla más
adelante, por ejemplo, si inicialmente agrega una tabla de junio y luego desea agregar una segunda tabla a
partir de julio.

En este ejemplo, agregamos otra tabla con campos similares a la tabla concatenada que creamos
anteriormente.

Aquí está la muestra de datos. Denominamos a la pestaña que contiene la tabla: DataTable_Newest.
Denominamos el archivo de datos: Concatenate_Data2.xlsx.

DataTable_Newest
DataTable_Newest
Fecha de
SalesOrderI SalesOrderDetailI TrackingNumb OrderQt UnitPric
ZIP ID modificació
D D er y e
n

43666 34 568E-472E-9C 2001 3 76 377.51301 7/12/2013


2 4 0:00

43666 34 568E-472E-9C 2322 5 77 377.51301 7/12/2013


0 0 0:00

Gestión de datos - Qlik Sense, June 2019 98


3   Administrar los datos de la app con el Gestor de datos

Fecha de
SalesOrderI SalesOrderDetailI TrackingNumb OrderQt UnitPric
ZIP ID modificació
D D er y e
n

43667 35 AB6C-4FF9-9D 3000 2 73 165.54438 7/13/2013


4 0 0:00

43668 36 AB6C-4FF9-9D 1121 4 75 787.3146 7/14/2013


5 4 0:00

43668 36 AB6C-4FF9-9D 5540 3 72 165.54438 7/14/2013


1 5 0:00

43668 36 AB6C-4FF9-9D 2000 5 76 377.51301 7/14/2013


3 2 0:00

43668 36 AB6C-4FF9-9D 1521 3 76 377.51301 7/14/2013


3 5 0:00

43669 37 C618-4998-BE 3312 2 76 377.51301 7/15/2013


5 8 0:00

43669 37 C618-4998-BE 1121 1 75 1932.2658 7/15/2013


5 3 0:00

Haga lo siguiente:

1. Desde el centro de control de Qlik Sense, haga clic en la app que creó en el procedimiento anterior. La
app se abre.
2. Seleccione Gestor de datos de la lista desplegable en la barra de herramientas superior. El Gestor de
datos se abre y se muestra la tabla que creó en el procedimiento anterior.

3. Haga clic en el botón ú para agregar datos.


4. Agregue el nuevo archivo de Excel a la app arrastrándolo al diálogo Adjuntar archivos a esta app.

Gestión de datos - Qlik Sense, June 2019 99


3   Administrar los datos de la app con el Gestor de datos

La ventana Añadir datos se abre.


5. Haga clic en Añadir datos para añadir la tabla de datos a la app.
La nueva tabla se añade a su app.

6. Ahora puede concatenar las tablas, editar las correspondencias y cargar los datos.
Para más información, vea Concatenar tablas y cargar tablas de datos en una app (page 95).

3.16 Sincronizar tablas de script en el Gestor de datos


De forma predeterminada, las tablas de script agregadas en el editor de carga de datos no pueden utilizar las
herramientas disponibles en el Gestor de datos. Por ejemplo, no puede asociar tablas de script con otras
tablas en el Gestor de datos ni transformar campos en tablas de script utilizando los paneles de perfiles de
datos. Si sincroniza sus tablas de script en el Gestor de datos, puede reemplazar sus tablas de script en el
Gestor de datos por tablas de script gestionadas. Estas tablas tienen acceso a las mismas herramientas que las
tablas agregadas en el Gestor de datos, incluyendo:

l Editar tablas, por ejemplo añadiendo campos calculados.


l Transformar campos, por ejemplo cambiando los tipos de campos o transformando campos con los
paneles de perfiles de datos.
l Transformar tablas, por ejemplo despivotar o concatenar tablas.

La sincronización y las tablas de script gestionadas tienen las siguientes limitaciones:

l Las tablas de script deben estar ubicadas antes de la Sección generada automáticamente en el script
de carga de datos para sincronizarse como tablas de script gestionadas. Las tablas que vengan tras la
Sección generada automáticamente en el script de carga de datos no se sincronizarán.
l No puede utilizar Seleccionar datos fuente para cambiar la selección de campos en una tabla de
script gestionada.

Gestión de datos - Qlik Sense, June 2019 100


3   Administrar los datos de la app con el Gestor de datos

No sincronice sus tablas con script si su script de carga de datos contiene una sentencia Exit o
campos dinámicos.

Para convertir sus tablas de script en tablas de script gestionadas, sincronice sus tablas de script en el Gestor
de datos. La sincronización hace lo siguiente:

l Reemplaza todas las tablas de script sincronizadas por tablas de script gestionadas.
l Elimina las tablas de script gestionadas cuyas tablas de script se hayan eliminado en el script de carga
de datos.
l Actualiza las tablas de script gestionadas cuyas tablas de origen se hayan modificado en el script de
carga de datos.

Si tiene tablas sincronizadas, no debe realizar cambios en el editor de carga de datos con el
Gestor de datos abierto en otra pestaña.

Evite modificar el script de carga de datos para tablas que ya se hayan sincronizado en el
Gestor de datos. Si elimina o modifica campos en el editor de carga de datos, debe
eliminar o rehacer cualquier campo derivado o asociaciones en la tabla sincronizada. Los
campos derivados que utilicen un campo eliminado o modificado, por ejemplo un campo
calculado o campos creados con el panel Dividir, muestran valores nulos.

Tras la sincronización, puede utilizar las tablas de script gestionadas en el Gestor de datos como cualquier
otra tabla. El Gestor de datos le pide que vuelva a sincronizar si detecta diferencias entre una tabla de script
gestionada y la tabla de script original.

Para cambiar las tablas de script gestionadas de nuevo en tablas de script, elimínelas en el Gestor de datos.
Debe repetir la eliminación si vuelve a sincronizar.

Sincronizar tablas de script


Haga lo siguiente:

1. En el Gestor de datos, haga clic en ¥ .


También puede seleccionar una tabla de script si lo prefiere.
2. Haga clic en Sincronizar tablas de script.

Las tablas de script gestionadas reemplazan a todas las tablas de script del Gestor de datos.

Eliminar las tablas de script gestionadas


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 101


3   Administrar los datos de la app con el Gestor de datos

1. En el Gestor de datos, seleccione la vista de Tablas.


2. En la tabla con script gestionada que desee eliminar, haga clic en Ö .
3. Haga clic en Cargar datos.

La tabla de script gestionada vuelve a ser de nuevo una tabla de script normal.

3.17 Gestionar las asociaciones de datos


Qlik Sense puede perfilar sus datos para ayudarle a crear asociaciones entre tablas. Puede
hacer asociaciones eligiendo entre las recomendaciones de análisis que propone Qlik Sense o
creando las suyas propias.

Si desea asociar sus datos, le recomendamos que utilice la opción Añadir datos con el perfilado de datos
habilitado. Esta es la opción predeterminada. Puede verificar esta configuración haciendo clic en ¥  junto al
botón Añadir datos en la esquina inferior derecha de la página Añadir datos.

En la vista Asociaciones del Gestor de datos sus datos se ilustran mediante burbujas, cada burbuja
representa una tabla de datos. El tamaño de la burbuja representa la cantidad de datos de la tabla. Los enlaces
entre las burbujas representan las asociaciones entre las tablas. Si hay una asociación entre dos tablas, puede
hacer clic en el botón del enlace para ver o editar la asociación.

En la mayoría de los casos, es más fácil editar las asociaciones de tablas en la vista modelo, pero
también puede editar las asociaciones de una sola tabla usando la opción Asociar en la vista de
edición de tablas.

Para más información, vea Asociar datos en el editor de tablas (page 54).

Gestión de datos - Qlik Sense, June 2019 102


3   Administrar los datos de la app con el Gestor de datos

Asociar tablas usando el panel Asociaciones recomendadas


En muchos casos Qlik Sense recomendará asociaciones entre tablas de datos. El panel Asociaciones
recomendadas le permite ver y aplicar estas recomendaciones.

El panel Asociaciones recomendadas se abrirá de forma predeterminada si hay tablas presentes. Se puede
cerrar haciendo clic en x en la esquina superior derecha o haciendo clic en Ñ . Se puede volver a abrir
haciendo clic en Ñ .

Si el panel está cerrado y existen recomendaciones, verá una placa en la parte superior de la Ñ que muestra
el número de recomendaciones.

Haga lo siguiente:

1. Haga clic en Ñ en la esquina superior derecha de la vista de asociaciones, si el panel de Asociaciones


recomendadas está cerrado.
El panel aparece a la derecha.
2. Verá la información siguiente:
l Total de tablas: el número total de tablas.
l Tablas no asociadas: el número total de tablas que no tienen asociaciones.
l Recomendaciones: el número total de asociaciones recomendadas.

Gestión de datos - Qlik Sense, June 2019 103


3   Administrar los datos de la app con el Gestor de datos

l Detalles de asociación recomendados: muestra el nombre de la asociación recomendada y a


continuación los nombres de tabla y campo separados por dos puntos
3. Haga clic en una única recomendación para obtener una vista previa en azul oscuro.
4. Para aceptar solo algunas de las recomendaciones, haga clic en el botón Aplicar para obtener la
recomendación específica que necesita.
5. Haga clic en Vista previa para ver cómo todas las asociaciones recomendadas afectarán a sus tablas
de datos. Las asociaciones que disponen de vista previa se destacan en azul claro.

6. Haga clic en Aplicar todas para aplicar todas las asociaciones recomendadas. Las asociaciones que
han sido aceptadas se destacan en gris claro.
Puede hacer clic en j en la parte inferior de la pantalla para ver cómo han cambiado tus tablas.

Ahora puede comenzar a hacer visualizaciones con sus datos.

Asociar las tablas manualmente


Puede asociar las tablas manualmente, arrastrándolas conjuntamente. Cuando arrastre las burbujas de la tabla
una hacia otra, se marcarán con una franja verde, naranja o roja.

l Verde: el Gestor de datos tiene plena confianza sobre qué campos asociar. Por ejemplo, si dos tablas
tienen campos etiquetados como "Sales Region", el Gestor de datos da por hecho que deben estar
asociados.

Gestión de datos - Qlik Sense, June 2019 104


3   Administrar los datos de la app con el Gestor de datos

l Naranja: el Gestor de datos tiene bastante confianza en que esas tablas se pueden asociar. Por
ejemplo, si dos campos diferentes tienen etiquetas diferentes, pero contienen datos de un solo dígito, el
Gestor de datos los marcará en naranja porque los tipos de datos son similares.
l Rojo: el Gestor de datos no sabe cómo asociar estas tablas. Deberá elegir qué tablas y campos van
juntos en el editor de Tablas asociadas.

Deseo asociar manualmente las tablas de color verde o naranja

Haga lo siguiente:

1. Arrastre una tabla a una de las tablas marcadas en verde o naranja.


2. La asociación se aplica automáticamente.

Las tablas están asociadas ahora utilizando los campos recomendados.

Deseo asociar manualmente las tablas de color rojo

Puede asociar las tablas creando una asociación personalizada.

Haga lo siguiente:

1. Arrastre una tabla a una de las tablas marcadas en rojo.


Se abre el editor Asociar tablas.
2. En la tabla de la izquierda, seleccione los campos que desee utilizar en la asociación.
Puede elegir un único campo o múltiples campos. También puede agregar caracteres delimitadores
para que sea más fácil interpretar los datos o para hacer coincidir un campo que ya existe. Puede ver el
aspecto que presenta la asociación de datos en la vista previa.
3. En la tabla de la derecha, seleccione los campos que desee utilizar de modo que coincida con las
selecciones realizadas en la tabla de la izquierda.
4. Introduzca un nombre para el campo clave que se creará en Nombre.
Este nuevo nombre de campo no puede ser igual a un nombre de campo ya existente en ninguna de las
tablas.
5. Haga clic en Asociar.

Las tablas se asocian ahora utilizando su asociación recomendada.

Romper las asociaciones


Hay dos formas de romper las asociaciones que no sean adecuadas para su modelo de datos.

Haga lo siguiente:

l Haga clic en una de las tablas asociadas y arrástrela fuera de la otra tabla hasta que la asociación se
rompa. O también puede:
l Hacer clic en el enlace entre las dos burbujas y después hacer clic en el botón Eliminar en el panel
inferior.

Las dos tablas ya no están asociadas.

Gestión de datos - Qlik Sense, June 2019 105


3   Administrar los datos de la app con el Gestor de datos

Editar las asociaciones


Puede editar una asociación existente entre dos tablas si necesita ajustar el modelo de datos.

Haga lo siguiente:

1. Haga clic en el círculo entre las tablas asociadas para abrir el panel de datos.
El panel se abre con una vista previa de los datos en los campos asociados.
2. Haga clic enk @ .
Verá uno o más botones, cada uno marcado en verde, naranja o rojo. Verde significa que el
Administrador de datos tiene confianza en la asociación, naranja significa que confía un poco y rojo
significa que está inseguro. La asociación actual está marcada en gris.
3. Haga clic en uno de los botones de asociación:
l Haga clic en una asociación recomendada para seleccionarla.
l Haga clic en una asociación personalizada (@ ) para editar qué campos usar en la asociación.
l Haga clic en Asociación personalizada para crear una nueva asociación.
Este botón solo está disponible si hay una asociación recomendada para el par de tablas.
Las asociaciones personalizadas pueden contener un solo campo o múltiples campos.

Ahora ha cambiado la asociación entre el par de tablas.

Vista previa de los datos


Puede obtener una vista previa de las tablas en la vista de asociaciones para una mejor comprensión de los
datos.

Haga lo siguiente:

1. Seleccione una tabla.


2. Haga clic en j en la parte inferior de la vista.

El panel de vista previa se muestra con los datos de la tabla.

Claves sintéticas
Cuando dos o más tablas de datos tienen dos o más campos en común, esto sugiere una relación de claves
compuestas. Qlik Sense manipula esto creando claves sintéticas automáticamente. Dichas claves son campos
anónimos que representan todas las combinaciones posibles de la clave compuesta.

Para más información, vea Claves sintéticas (page 143).

Si añadir una tabla da como resultado uno de los casos siguientes, solo puede añadir datos con el perfilado de
datos habilitado:

l Se ha creado una clave sintética que contiene más de cinco campos.


l Se han creado más de diez claves sintéticas.
l Se han creado claves sintéticas anidadas, es decir, claves sintéticas que contienen otras claves sintéticas.

Todos estos casos indican que debemos ajustar las tablas de datos para resolver los problemas.

Gestión de datos - Qlik Sense, June 2019 106


3   Administrar los datos de la app con el Gestor de datos

Limitaciones
En algunos casos no se ofrecen recomendaciones de asociación debido a la estructura de las tablas cargadas y
a los datos de las tablas. En estos casos, debe ajustar las asociaciones en el editor de tablas.

l Relaciones de muchos a muchos.


l Pares de campos con datos que no combinan bien en ambas direcciones. Este puede ser el caso cuando
tenemos una tabla pequeña con unos cuantos valores de campo que coinciden al 100% con un campo
de otra tabla mayor, pero la coincidencia en la otra dirección es significativamente menor.
l Asociaciones de claves compuestas.

Además, el Gestor de datos solo analizará las tablas que se agregaron mediante Añadir datos. Las tablas
agregadas usando el script de carga de datos no se incluyen en las recomendaciones de asociación, a menos
que se hayan sincronizado en el Gestor de datos.

Para más información, vea Sincronizar tablas de script en el Gestor de datos (page 100).

Aplicar los cambios y volver a cargar los datos


Los cambios que haya efectuado en el Gestor de datos no estarán disponibles en la app hasta que haya
cargado los datos. Cuando carga los datos, se aplican los cambios y cualquier dato nuevo que haya añadido se
carga desde las fuentes de datos externas. Los datos que haya cargado previamente no se cargan.

Puede volver a cargar todos los datos de las fuentes externas de datos utilizando el botón ô en el pie de
página del Gestor de datos.

El botón ô carga todos los datos de la tabla seleccionada. No carga todos los datos de todas las tablas de la
app.

Si los datos del Gestor de datos no están sincronizados con los datos de la app, el botón Cargar datos se
muestra de color verde. En la vista Asociaciones, todas las tablas nuevas o actualizadas se indican mediante un
asterisco * y las tablas eliminadas se ven de un color gris más claro. En la vista Tablas, todas las tablas nuevas,
actualizadas o eliminadas se destacan de color azul y muestran un icono que indica el estado de la tabla:

l Las tablas marcadas con Pendiente de eliminar Ö se eliminarán.


l Las tablas marcadas con Pendiente de actualizar ô se actualizarán con campos que se hayan
añadido, cambiado de nombre o eliminado, o se cambiará el nombre de la tabla.
l Las tablas marcadas con Pendiente de añadir m se añadirán

Aplicar los cambios


Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 107


3   Administrar los datos de la app con el Gestor de datos

l Haga clic en Cargar datos para cargar los cambios en la app.

Los datos de la app se actualizan ahora con los cambios que realizó en el Gestor de datos.

Gestión de datos - Qlik Sense, June 2019 108


4   Cargar datos con el script de carga de datos

4 Cargar datos con el script de carga de datos


Esta introducción sirve como una presentación breve de cómo podemos cargar datos en Qlik Sense usando
scripts de carga de datos.

Qlik Sense utiliza un script de carga de datos, el cual se gestiona desde el editor de carga de datos, para poder
conectarse a diversas fuentes de datos y recuperar los datos alojados en ellas. Una fuente de datos puede ser un
archivo de datos, por ejemplo un archivo Excel o un archivo .csv. Una fuente de datos también puede ser una
base de datos, por ejemplo un Google BigQuery o base de datos de Salesforce.

También se pueden cargar datos desde el gestor de datos, pero cuando desee crear, editar y ejecutar un script
de carga de datos utilice el editor de carga de datos.

En el script se especifican los campos y las tablas que se van a cargar. Los scripts se utilizan a menudo para
especificar qué datos se van a cargar desde sus fuentes de datos. También puede manipular la estructura de
datos mediante sentencias de script.

Durante la carga de datos, Qlik Sense identifica los campos comunes a distintas tablas (campos clave) para
asociar los datos. La estructura de datos resultante de la app se puede monitorizar en el visor del modelo de
datos. Se pueden hacer cambios en la estructura de datos renombrando los campos, para así obtener diferentes
asociaciones entre las tablas.

Una vez que se han cargado los datos en Qlik Sense, se almacenan en la app.

El análisis en Qlik Sense siempre se produce mientras la app no está directamente conectada con sus fuentes de
datos. En consecuencia, para actualizar los datos, debemos ejecutar el script para recargar los datos.

4.1 Interacción entre el Gestor de datos y el script de carga


de datos
Cuando añadimos tablas de datos en el Gestor de datos, se genera un código de script de carga. Podemos ver
el código de script en la Sección generada automáticamente del editor de carga de datos. También podemos
desbloquear y editar el código de script generado, pero si lo hacemos, las tablas de datos ya no se podrán
gestionar más desde el Gestor de datos.

Las tablas de datos definidas en el script de carga no se gestionan desde el Gestor de datos de forma
predeterminada. Es decir, podremos ver las tablas en la vista general de datos, pero no podremos eliminar o
editar las tablas en el Gestor de datos, y no se ofrecen recomendaciones de asociaciones para tablas cargadas
mediante el script. Si sincroniza sus tablas de script con el Gestor de datos no obstante, sus tablas de script se
añadirán como tablas de script gestionadas al Gestor de datos.

Si tiene tablas sincronizadas, no debe realizar cambios en el editor de carga de datos con el Gestor
de datos abierto en otra pestaña.

Gestión de datos - Qlik Sense, June 2019 109


4   Cargar datos con el script de carga de datos

Podemos añadir secciones al script y desarrollar código que mejore e interactúe con el modelo de datos creado
en el Gestor de datos, pero hay algunas áreas en las que debemos ir con cuidado. El código de script que
escribamos puede interferir con el modelo de datos del Gestor de datos y crear problemas en los siguientes
casos:

l Renombrar o eliminar tablas añadidas con el Gestor de datos en el script.


l Eliminar campos de tablas añadidas con el Gestor de datos.
l Concatenación entre tablas añadidas con el Gestor de datos y tablas cargadas en el script.
l Utilizar la sentencia Qualify con campos en tablas añadidas con el Gestor de datos.
l Cargar tablas añadidas con el Gestor de datos utilizando Resident en el script.
l Añadir código de script tras la sección de código generada. Los cambios resultantes en el modelo de
datos no se reflejan en el Gestor de datos.

4.2 Usar el editor de carga de datos


Esta sección describe cómo utilizar el editor de carga de datos para crear o editar un script de carga de datos
que puede usarse para cargar su modelo de datos en la app.

El script de carga de datos conecta una app con una fuente de datos y carga datos de la fuente de datos a la
app. Cuando haya cargado los datos, estará disponible para hacer análisis con la app. Cuando desee crear,
editar y ejecutar un script de carga de datos, utilice el editor de carga de datos.

Puede editar un script manualmente, o puede generarlo con el gestor de datos. Si necesita utilizar sentencias de
script complejas, debe editarlas manualmente.

Ejemplo del editor de carga de datos.

Gestión de datos - Qlik Sense, June 2019 110


4   Cargar datos con el script de carga de datos

A: La barra de herramientas
Barra de herramientas con los comandos más utilizados para el editor de carga de datos: menú global, u
(depurar) y Cargar datos  ° . En la barra de herramientas, también se muestran los estados de guardado y
carga de datos de la app.

B: Conexiones de datos
En Conexiones de datos podemos guardar métodos abreviados (atajos) a las bases de datos o archivos
remotos que más utilizamos. Aquí también es donde se inicia la selección de los datos que se deben cargar.

C: Editor de texto
Podemos escribir y editar el código de script en el editor de texto. Cada línea del script está numerada y el script
viene codificado por colores según sus componentes de sintaxis. La barra de herramientas del editor de texto
contiene comandos para Buscar y reemplazar, el modo de Ayuda, Deshacer y Rehacer. El script inicial ya
contiene algunas configuraciones de variables regionales predefinidas, por ejemplo el separador de miles SET
ThousandSep=, que por lo general no necesita editar.

D: Secciones
Podemos dividir el script en secciones para hacerlo más sencillo de leer y mantener. Las secciones se ejecutan de
arriba a abajo.

Si ha añadido datos utilizando Añadir datos, tendrá una sección en el script de carga de datos denominada
Sección generada automáticamente que contiene el código de script requerido para cargar los datos.

E: Salida
Salida muestra el estatus de guardado automático y todos los mensajes que se generan durante la ejecución
del script.

Inicio rápido
Si desea cargar un archivo o tablas de una base de datos, es necesario realizar los siguientes pasos en
Conexiones de datos:

1. Cree una nueva conexión vinculada al origen de datos (si la conexión de datos todavía no existe).
2. ± Seleccione datos desde la conexión.

Cuando haya completado el diálogo de selección con Insertar script, puede seleccionar Cargar datos para
cargar el modelo de datos en la app.

Para obtener información más detallada sobre las funciones de script y las funciones de gráfico,
consulte la ayuda online de Sintaxis de script y funciones de gráficos.

Gestión de datos - Qlik Sense, June 2019 111


4   Cargar datos con el script de carga de datos

Barras de herramientas
Las barras de herramientas permiten realizar acciones generales en el script de carga de datos, como
deshacer/rehacer, depurar y buscar/reemplazar. También puede hacer clic en Cargar datos ° para recargar
los datos de su app.

Barra de herramientas principal


Opciones de la barra de herramientas principal
Opción Descripción

Menú global con opciones de navegación y acciones que puede realizar en su app.

Datos Haga clic en la pestaña para realizar tareas de datos. Por ejemplo, puede cargar datos en el
Gestor de datos o el Editor de carga de datos, o ver el modelo de datos en el Visor del
modelo de datos.

La pestaña Datos no está disponible en una app publicada, a menos que sea el propietario de
la app. En ese caso, solo puede abrir el Visor del modelo de datos.

Análisis Haga clic en la pestaña para realizar tareas de análisis. Por ejemplo, puede crear o interactuar
con tablas y gráficos.

Historia Haga clic en la pestaña para crear historias en su app.

⊟ Puede mostrar u ocultar la información de la app, editar la información o abrir las opciones
de la app y dar estilo a su app.

Una vez que la app se ha publicado, no se puede editar la información de la app ni


abrir las opciones de la app.

u Depura el script.

° Cargar Ejecute el script para cargar los datos. La app se guarda automáticamente antes de la
datos recarga.

h Alternar la vista Conexiones de datos.

Barra de herramientas Editor


Opciones de la barra de herramientas Editor
Opción Descripción

F Busca y remplaza texto en el script.

… Comenta/elimina el comentario.

À Indenta o añade una sangría.

Gestión de datos - Qlik Sense, June 2019 112


4   Cargar datos con el script de carga de datos

Opción Descripción

à Elimina el indentado o sangría.

D Activa el modo de ayuda de la sintaxis. En el modo de ayuda podemos hacer clic en una palabra
clave de la sintaxis (marcada en azul) en el editor, para acceder a una ayuda detallada de sintaxis.

No es posible editar el script en el modo de ayuda.

B Deshace el último cambio realizado en la sección actual (se pueden deshacer múltiples pasos).
Equivale a pulsar Ctrl+Z.

C Rehace la última acción Deshacer en la sección actual. Equivale a pulsar Ctrl+Y.

Conectar con fuentes datos en el editor de carga de datos


Las conexiones de datos en el editor de carga de datos permiten guardar accesos directos a las fuentes de datos
utilizadas con más frecuencia: bases de datos, archivos locales o archivos remotos. En Conexiones de datos
figuran las conexiones de datos guardadas por orden alfabético. Puede utilizar el cuadro de búsqueda/filtro
para reducir la lista a conexiones con un determinado nombre o tipo.

Solo puede ver las conexiones de datos que le pertenezcan o para las que disponga de derechos de
acceso. Póngase en contacto con su administrador de sistemas de Qlik Sense para solicitar acceso,
si lo necesita.

Crear una nueva conexión de datos


Haga lo siguiente:

1. Haga clic en Crear nueva conexión.


2. Seleccione el tipo de fuente de datos que desee crear en la lista desplegable.
Se abrirá el diálogo de configuración específico del tipo de origen de datos que haya seleccionado.
3. Introduzca las configuraciones de fuentes de datos y haga clic en Crear para crear la conexión de datos.
El nombre de la conexión se añadirá a su nombre de usuario y dominio para asegurar que es único.

Ahora se ha creado la conexión de datos con usted como el propietario predeterminado. Si desea que otros
usuarios puedan utilizar la conexión en una instalación de servidor, necesita editar los derechos de acceso de la
conexión en la consola Qlik Management Console.

La configuración de la conexión que se ha creado no se actualizará automáticamente si se modifica


la configuración del origen de datos. Esto significa que debe tener cuidado con el almacenamiento
de nombres de usuario y contraseñas, especialmente si cambia la configuración entre la seguridad
integrada de Windows y los inicios de sesión de la base de datos en el DSN.

Gestión de datos - Qlik Sense, June 2019 113


4   Cargar datos con el script de carga de datos

Si no aparece Crear nueva conexión, significa que no posee los derechos de acceso necesarios
para añadir conexiones de datos. Póngase en contacto con su administrador de sistemas de Qlik
Sense para solicitar acceso, si lo necesita.

Eliminar una conexión de datos


Haga lo siguiente:

1. Haga clic en Ö en la tabla de datos que desee eliminar.


2. Confirme que desea eliminar la conexión.

Ahora se ha eliminado la conexión de datos.

Si no aparece Ö , eso significa que no posee los derechos de acceso necesarios para eliminar la
conexión de datos. Póngase en contacto con su administrador de sistemas de Qlik Sense para
solicitar acceso, si lo necesita.

Editar una conexión de datos


Haga lo siguiente:

1. Haga clic en @ en la tabla de datos que desee editar.


2. Edite los detalles de la conexión de datos. Los detalles de la conexión son específicos según el tipo de
conexión.

La conexión de datos se actualiza.

Si edita el nombre de una conexión de datos, también debe editar todas las referencias existentes
(lib://) a la conexión en el script, si desea seguir consultando la misma conexión.

Si no aparece @ , eso significa que no posee los derechos de acceso necesarios para actualizar la
conexión de datos. Póngase en contacto con su administrador de sistemas de Qlik Sense, si lo
necesita.

Insertar una cadena de conexión


Las cadenas de conexión son necesarias para la mayoría de conexiones. Las únicas conexiones que no requieren
cadenas de conexión son las conexiones de carpetas y archivos web.

Haga lo siguiente:

l Haga clic en Ø en la conexión para la que desee insertar una cadena de conexión.

Gestión de datos - Qlik Sense, June 2019 114


4   Cargar datos con el script de carga de datos

Se inserta una cadena de conexión para la conexión de datos seleccionada en la posición actual del editor de
carga de datos.

También puede insertar una cadena de conexión si arrastra una conexión de datos y la suelta en la
posición del script en la que desee insertarla.

Seleccionar datos de una conexión de datos


Si desea seleccionar datos de una conexión de datos para cargar en su app, haga lo siguiente:

1. Cree una conexión nueva vinculada a la fuente de datos (si la conexión de datos no existe todavía).
2. ± Seleccione datos desde la conexión.

Referencia a una conexión de datos en el script


Puede usar la conexión de datos para hacer referencia a fuentes de datos en las sentencias y las funciones del
script, normalmente cuando desea remitir a un nombre de archivo con una ruta.

La sintaxis para referirse a un archivo es 'lib://(connection_name)/(file_name_including_path)'

Ejemplo: Cargar un archivo desde una conexión de datos de carpeta

Este ejemplo carga el archivo orders.csv desde la ubicación definida en la conexión de datos MyData.

LOAD * FROM 'lib://MyData/orders.csv';

Ejemplo: Cargar un archivo desde una subcarpeta

Este ejemplo carga el archivo Customers/cust.txt desde la carpeta de conexión de datos DataSource. Customers
es una subcarpeta en la ubicación definida en la conexión de datos MyData.

LOAD * FROM 'lib://DataSource/Customers/cust.txt';

Ejemplo: Cargar desde un archivo web

Este ejemplo carga una tabla desde la conexión de datos de archivos web PublicData, el cual contiene la URL
real.

LOAD * FROM 'lib://PublicData' (html, table is @1);

Ejemplo: Cargar desde una base de datos

Este ejemplo carga la tabla Sales_data desde la carpeta de conexión de datos MyDataSource.

LIB CONNECT TO 'MyDataSource';


LOAD *;
SQL SELECT * FROM `Sales_data`;

Gestión de datos - Qlik Sense, June 2019 115


4   Cargar datos con el script de carga de datos

¿Dónde se almacena la conexión de datos?


Las conexiones se almacenan utilizando Qlik Sense Repository Service.Puede gestionar conexiones de datos con
la consola Qlik Management Console en un despliegue de servidor Qlik Sense. La consola Qlik Management
Console le permite eliminar conexiones de datos, establecer derechos de acceso y realizar otras tareas de
administración de sistemas.

En Qlik Sense Desktop todas las conexiones se guardan en la app sin cifrar. Ello incluye los posibles
detalles sobre el nombre de usuario, contraseña y la ruta de archivo que se ha introducido al crear
la conexión. Esto significa que todos estos detalles pueden estar disponibles en forma de texto no
cifrado si comparte la app con otro usuario. Este hecho debe tenerse en cuenta cuando se diseñe
una app que vaya a compartirse.

Seleccionar datos en el editor de carga de datos.


Podemos seleccionar qué campos queremos cargar desde archivos o tablas de bases de datos y qué vistas de la
fuente de datos deseamos usando el diálogo interactivo Seleccionar datos. Además de seleccionar los campos,
también podemos renombrar los campos en el diálogo. Cuando haya terminado de seleccionar los campos,
puede insertar el código de script generado en su script.

Algunas fuentes de datos, como un archivo CSV, contienen una sola tabla, mientras que otras fuentes de datos,
como las bases de datos u hojas de cálculo de Microsoft Excel, pueden contener varias tablas.

No agregue una tabla en el Editor de carga de datos que ya se haya agregado como una tabla
con secuencias de script con el mismo nombre y las mismas columnas que en el Gestor de datos.

Seleccionar datos se abre haciendo clic en ± en una conexión de datos en el editor de carga de datos.

Seleccionar datos de una base de datos


Cuando seleccione datos de una base de datos, la fuente de datos puede contener varias tablas.

Haga lo siguiente:

1. Haga clic en ± en una conexión de base de datos en el editor de carga de datos.


Aparece el diálogo de selección de datos.
2. Seleccione una Base de datos de la lista desplegable.
Algunos diálogos de selección no tienen una lista desplegable Base de datos porque se introduce el
nombre de la base de datos cuando se configura la conexión.
3. Seleccione el Propietario de la base de datos.
La lista de Tablas se puebla de vistas y tablas disponibles en la base de datos seleccionada.
Algunas bases de datos no requieren que se especifiquen los propietarios en el proceso de selección de
datos.
4. Seleccione una tabla.

Gestión de datos - Qlik Sense, June 2019 116


4   Cargar datos con el script de carga de datos

5. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar.
Puede seleccionar todos los campos de la tabla marcando la casilla situada junto al nombre de tabla.

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

6. Seleccione tablas adicionales si desea añadir datos de las mismas.

No puede renombrar campos en el asistente de selección de datos al mismo tiempo que


filtra los campos buscándolos. Tiene que borrar primero la cadena de búsqueda del cuadro
de texto.

No es posible renombrar dos campos en la misma tabla para que tengan nombres idénticos.

7. Cuando haya terminado su selección de datos, haga lo siguiente:


l Haga clic en Insertar script.
La ventana de selección de datos se cierra y las sentencias LOAD/SELECT se insertan en el script
de acuerdo con sus selecciones.

Seleccionar datos desde una hoja de cálculo de Microsoft Excel


Cuando selecciona datos desde una hoja de cálculo de Microsoft Excel, el archivo puede contener varias hojas.
Cada hoja se carga como una tabla aparte. Una excepción es si la hoja tiene la misma estructura de
campos/columnas que otra hoja o tabla cargada, en cuyo caso las tablas se concatenan.

Haga lo siguiente:

1. Haga clic en ± en la conexión de carpeta adecuada en el editor de carga de datos.


Se abrirá el cuadro de diálogo de selección de archivos.
2. Seleccione un archivo de la lista de archivos accesibles desde esta conexión de carpeta.
3. Seleccione la primera hoja de la que seleccionar datos. Puede seleccionar todos los campos de una hoja
marcando la casilla situada junto al nombre de hoja.
4. Asegúrese de tener los parámetros adecuados para la hoja:

Gestión de datos - Qlik Sense, June 2019 117


4   Cargar datos con el script de carga de datos

Configuración para ayudarlo a interpretar los datos de la tabla correctamente


Elemento
Descripción
de IU

Nombres Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de


de campo campo. Normalmente, en una hoja de cálculo de Excel, la primera fila contiene los
nombres de campo incluidos. Si selecciona Sin nombres de campo, los campos se
denominarán A,B,C...

Tamaño Defina el número de filas que se deben omitir como cabecera de tabla, por lo general
de filas que contengan información general que no esté en un formato de columna.
cabecera

Ejemplo
La hoja de cálculo presentará el siguiente aspecto:
Hoja de cálculo
Equipo: AEJ12B - -

Fecha: 2015-10-05 09 - -

Fecha-hora Orden Operador Resultado

2015-10-05 09:22 00122344 A 52

2015-10-05 10:31 00153534 A 67

2015-10-05 13:46 00747899 B 86

En este caso probablemente desee ignorar las dos primeras líneas y cargar una tabla con los campos
Timestamp, Order, Operator y Yield. Para lograr esto, utilice estos parámetros:
Parámetros para ignorar las dos primeras líneas y cargar los campos
Elemento
Descripción
de IU

Tamaño 2
de Esto significa que las dos primeras líneas se consideran datos de cabecera y se ignoran
cabecera cuando se carga el archivo. En este caso, las dos líneas que comienzan con Machine: y
Date: se ignoran, ya que no son parte de los datos de la tabla.

Nombres Nombres de campo incluidos


de campo Esto significa que la primera línea que se lee se utiliza como nombres de campo para las
respectivas columnas. En este caso, la primera línea que se leerá es la tercera, porque las
dos primeras líneas son datos de cabecera.

5. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar.

Gestión de datos - Qlik Sense, June 2019 118


4   Cargar datos con el script de carga de datos

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

6. Cuando haya terminado su selección de datos, haga lo siguiente:


l Haga clic en Insertar script.
La ventana de selección de datos se cierra y las sentencias LOAD/SELECT se insertan en el script
de acuerdo con sus selecciones.

También puede usar un archivo de Microsoft Excel como fuente de datos usando la interfaz ODBC.
En ese caso debe usar una conexión de datos ODBC en lugar de una conexión de datos Todos los
archivos.

Seleccionar datos de un archivo de tabla


Puede seleccionar datos de un amplio número de archivos de datos:

l Archivos de texto, donde los datos en los campos están separados por delimitadores como comas,
tabuladores o signos de punto y coma (archivos (CSV) de variables separadas por comas).
l Tablas HTML.
l Archivos XML.
l Archivos KML.
l Archivos nativos de Qlik QVD y QVX.
l Archivos de tabla con registros de longitud fija.
l Archivos DIF (Data Interchange Format).

Haga lo siguiente:

1. Haga clic en ± en la conexión de carpeta adecuada en el editor de carga de datos.


Se abrirá el cuadro de diálogo de selección de archivos.
2. Seleccione un archivo de la lista de archivos accesibles desde esta conexión de carpeta.
3. Asegúrese de que el tipo de archivo adecuado esté seleccionado en Formato de archivo.
4. Asegúrese de tener los parámetros adecuados para el archivo. Los parámetros de archivo son diferentes
según los distintos tipos de archivo.
5. Seleccione los campos que desee cargar marcando la casilla situada junto a cada campo que quiera
cargar. También puede seleccionar todos los campos de un archivo marcando la casilla situada junto al
nombre de hoja.

Puede editar el nombre de campo haciendo clic en el nombre de campo e introduciendo


uno nuevo. Esto puede afectar a la forma en que la tabla se asocia con otras tablas, puesto
que se asocian según los campos comunes de manera predeterminada.

Gestión de datos - Qlik Sense, June 2019 119


4   Cargar datos con el script de carga de datos

6. Cuando haya terminado su selección de datos, haga lo siguiente:


l Haga clic en Insertar script.
La ventana de selección de datos se cierra y las sentencias LOAD/SELECT se insertan en el script
de acuerdo con sus selecciones.

Escoger los parámetros para tipos de archivos


Archivos de tabla delimitados
Estas configuraciones se validan para archivos de tabla delimitados que contienen una única tabla en la que
cada registro va separado por un salto de línea y cada campo se separa con un carácter delimitado, por
ejemplo, un archivo CSV.

Configuraciones de formato de archivo para archivos de tabla delimitados


Elemento de IU Descripción

Formato de archivo para Elija Delimitado o Registro fijo.


archivos de tabla
delimitados Cuando haga una selección, el cuadro de diálogo de selección de datos se
adaptará al formato de archivo que haya seleccionado.

Nombres de campo Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres
de campo.

Delimiter Escoja el carácter Delimitador que se utilizará en su archivo de tabla.

Entrecomillado Especifique cómo se tratarán las comillas:

Ninguno = las comillas no se aceptan

Estándar = entrecomillado estándar (las comillas se pueden usar como


caracteres iniciales y finales del valor de un campo)

MSQ = estilo de comillas modernas (que permite un contenido de múltiples líneas


en los campos)

Tamaño de cabecera El número de líneas que desee omitir como cabecera de tabla.

Character set El juego de caracteres que se empleará en el archivo de tabla.

Comentario Los archivos de datos pueden contener comentarios entre registros, los cuales se
caracterizan por una línea inicial con uno o más caracteres especiales, por
ejemplo //.

Especifique uno o más caracteres que denotarán una línea de comentario. Qlik
Sense no carga líneas que comiencen con los caracteres aquí especificados.

Ignorar EOF Seleccione Ignorar EOF si sus datos contienen caracteres de final de archivo
como parte del valor de campo.

Gestión de datos - Qlik Sense, June 2019 120


4   Cargar datos con el script de carga de datos

Archivos de tabla con registros de longitud fija


Los archivos de registros de longitud fija contienen una única tabla en la que cada registro (cada fila de datos)
contiene varias columnas con un tamaño fijo de campo, normalmente rodeados de caracteres tipo espacios o
tabuladores.

Podemos configurar posiciones de salto de campo de dos maneras:

l Introduzca manualmente las posiciones de salto de campo separadas por comas en Posiciones de
salto de campo. Cada posición marca el inicio de un campo.

Example: 1,12,24

l Habilite Saltos de campo para editar las posiciones de salto de campo interactivamente en la vista
previa de los datos de campo. Las Posiciones de salto de campo se actualizan con las posiciones
seleccionadas. Podemos:
l Hacer clic en la vista previa de datos de campo para insertar un salto de campo.
l Hacer clic en un salto de campo para eliminarla.
l Arrastrar un salto de campo para moverlo.

Configuración de formato de archivo para archivos de datos de registro fijo


Elemento de IU Descripción

Nombres de campo Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de
campo.

Tamaño de cabecera Establezca el Tamaño de cabecera en el número de líneas que desee omitir como
cabecera de tabla.

Character set Establezca el juego de caracteres que se empleará en el archivo de tabla.

Tamaño de pestaña Defina el número de espacios que un carácter de tabulador representa en el


archivo de tabla.

Tamaño de línea de Defina el número de líneas que ocupa un registro en el archivo de tabla. Por defecto
registro es 1.

Archivos HTML.
Los archivos HTML pueden contener varias tablas. Qlik Sense interpreta todos los elementos con una etiqueta
<TABLE> como una tabla.

Configuración de formato de archivo para archivos HTML


Elemento de IU Descripción

Nombres de Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de


campo campo.

Character set Especifique el juego de caracteres empleado en el archivo de tabla.

Gestión de datos - Qlik Sense, June 2019 121


4   Cargar datos con el script de carga de datos

Archivos XML.
Puede cargar datos que estén almacenados en formato XML.

No hay configuraciones específicas de formato de archivo para los archivos XML.

Archivos QVD.
Puede cargar datos que estén almacenados en formato QVD. QVD es un formato nativo de Qlik y solo pueden
leerlo y escribirlo Qlik Sense o QlikView. El formato de archivo está optimizado para mejorar la velocidad de
lectura de datos desde un script Qlik Sense, pero es al mismo tiempo muy compacto.

No hay configuraciones específicas de formato de archivo para los archivos QVD.

Archivos QVX.
Puede cargar datos almacenados en formato Qlik data eXchange (QVX). Los archivos QVX se crean mediante
conectores personalizados desarrollados con Qlik QVX SDK.

No hay configuraciones específicas de formato de archivo para los archivos QVX.

Archivos KML.
Puede cargar archivos de mapas que estén almacenados en formato KML, para usarlos en visualizaciones de
mapas.

No hay configuraciones específicas de formato de archivo para los archivos KML.

Vista previa del script


Las sentencias que se insertarán se muestran en la vista previa del script, la cual se puede ocultar o no haciendo
clic en Mostrar vista previa de script.

Incluir sentencias LOAD


Si Incluir sentencia LOAD está seleccionado, las sentencias SELECT se generan con sentencias LOAD
precedentes usando las sentencias SELECT como entrada.

Si cambia el nombre de los campos de una tabla, se insertará una sentencia LOAD
automáticamente, independientemente de esta configuración.

Editar el script de carga de datos


Puede editar el script en el editor de texto del Editor de carga de datos. Aquí puede hacer cambios manuales a
las sentencias LOAD o SELECT que haya generado al seleccionar datos, y redactar nuevo script.

El script, que se debe escribir con la sintaxis de script de Qlik Sense, está codificado mediante colores para
facilitar la distinción de los diversos elementos. Los comentarios se resaltan en verde, mientras que las palabras
clave de la sintaxis de Qlik Sense se resaltan en azul. Cada línea de script está numerada.

Hay varias funciones disponibles en el editor para ayudarle a desarrollar el script de carga, y se describen en
esta sección.

Gestión de datos - Qlik Sense, June 2019 122


4   Cargar datos con el script de carga de datos

Acceder a la ayuda de sintaxis para comandos y funciones


Hay varias maneras de acceder a la ayuda de sintaxis de una palabra clave de sintaxis de Qlik Sense.

Acceder al portal de ayuda


Podemos acceder a la ayuda detallada del portal de ayuda de Qlik Sense de dos maneras.

l Haga clic en D en la barra de herramientas para entrar en el modo de ayuda de sintaxis. En el modo
de ayuda de la sintaxis podemos hacer clic en una palabra clave de la sintaxis (marcada en azul y
subrayada) para acceder a la ayuda detallada de sintaxis.
l Coloque el cursor en el interior o al final de la palabra clave y pulse Ctrl+H.

No puede editar el script mientras esté en el modo de ayuda de sintaxis.

Usando la función de autocompletar


Si empieza a escribir una palabra clave del script de Qlik Sense, se abre una lista de auto-completar con
palabras clave similares entre las que puede escoger. La lista se va reduciendo a medida que escribe y puede
seleccionar desde plantillas con sintaxis y parámetros sugeridos. Una información relativa a herramientas
muestra la sintaxis de la función, incluidos los parámetros y las sentencias adicionales, así como un enlace a la
descripción del portal de ayuda de la sentencia o función.

También puede usar el método abreviado de teclado Ctrl+Espacio para mostrar la lista de palabras
clave y Ctrl+Mayús+Espacio para mostrar una información relativa a herramientas.

Insertar un script de prueba preparado


Puede insertar un script de prueba ya preparado que cargará un conjunto de campos de datos inline. Puede
utilizar esto para crear con rapidez un conjunto de datos que le sirva para hacer pruebas.

Haga lo siguiente:

l Pulse Ctrl + 00.

El código de script de prueba se inserta en el script.

Indentado del código


Se puede indentar el código para mejorar la legibilidad.

Haga lo siguiente:

1. Seleccione una o varias líneas para cambiar el indentado.


2. Haga clic en À para indentar el texto (aumentar la sangría) o haga clic en à para reducir la
indentación del texto (reducir la sangría).

Gestión de datos - Qlik Sense, June 2019 123


4   Cargar datos con el script de carga de datos

También puede usar métodos abreviados de teclado:

Tabulador (indentar)

Mayús+Tabulador (eliminar indentado)

Buscar y reemplazar texto


Puede buscar y reemplazar texto en todas las secciones del script.

Buscar texto
Abra el editor de carga de datos. Haga lo siguiente:

1. Haga clic en F en la barra de herramientas.


Aparece el diálogo desplegable de búsqueda.
2. En el cuadro de búsqueda, escriba el texto que desea encontrar.
Los resultados de la búsqueda se resaltan en la sección actual del código de script. Además, el número de
instancias de texto halladas se indica junto a la etiqueta de sección.
3. Puede navegar por los resultados haciendo clic en ê y ë .
4. Haga clic en F en la barra de herramientas para cerrar el diálogo de búsqueda.

También puede seleccionar Buscar en todas las secciones para buscar en todas las secciones de
script. El número de instancias de texto encontradas se indica junto a cada etiqueta de sección.
Puede seleccionar Sensible a mayúsculas para realizar búsquedas sensibles a mayúsculas y
minúsculas.

Reemplazar texto
Haga lo siguiente:

1. Haga clic en F en la barra de herramientas.


Aparece el diálogo desplegable de búsqueda.
2. Introduzca el texto que desee buscar en el cuadro de búsqueda.
3. Introduzca el texto que desee reemplazar en el cuadro Reemplazar y haga clic en Reemplazar.
4. Haga clic en ë para hallar la siguiente instancia del texto de búsqueda y realizar una de las siguientes
acciones:
l Haga clic en Reemplazar para reemplazar el texto.
l Haga clic en ë para buscar el siguiente.
5. Haga clic en F en la barra de herramientas para cerrar el diálogo de búsqueda.

Gestión de datos - Qlik Sense, June 2019 124


4   Cargar datos con el script de carga de datos

Podemos seleccionar también Reemplazar todo en la sección para reemplazar todas las
instancias de la cadena de búsqueda en la actual sección de script. La función de reemplazo
distingue entre mayúsculas y minúsculas y, por tanto, el texto reemplazado tendrá el mismo
formato en el campo de reemplazo. Se muestra un mensaje con información sobre cuántas
instancias se han reemplazado.

Comentarios en el script
Puede insertar comentarios en el código de script o desactivar partes del código de script mediante el uso de
marcas de comentario. Todo el texto de una línea que vaya a la derecha de // (dos barras diagonales) se
considerará un comentario y no se ejecutará cuando se ejecute el script.

La barra de herramientas del editor de carga de datos contiene un acceso directo para añadir o eliminar
comentarios del código. La función actúa como un conmutador; Es decir, que si el código seleccionado no se
comenta, se comentará, y viceversa.

Comentar
Haga lo siguiente:

1. Seleccione una o más líneas de código que no estén comentadas o coloque el cursor al principio de una
línea.
2. Haga clic en … o pulse Ctrl + K.

El código seleccionado quedará comentado.

Descomentar
Haga lo siguiente:

1. Seleccione una o más líneas de código que esté comentadas o coloque el cursor al principio de una línea
comentada.
2. Haga clic en … o pulse Ctrl + K.

El código seleccionado ahora se ejecutará con el resto del script.

Hay más maneras de insertar comentarios en el código de script:

l Usando la sentencia Rem.


l Encerrando una sección de código entre /* y */.

Example:

Rem This is a comment ;

/* This is a comment
that spans two lines */

// This is a comment as well

Gestión de datos - Qlik Sense, June 2019 125


4   Cargar datos con el script de carga de datos

Seleccionar todo el código


Puede seleccionar todo el código completo en la actual sección de script.

Haga lo siguiente:

l Pulse Ctrl + A.

Todo el código se selecciona en la actual sección de script.

Organizar el código de script


Podemos dividir el script en secciones para organizar la estructura. El script se ejecuta en el orden de las
secciones de arriba a abajo. Un script debe contener al menos una sección.

Secciones Principal, Diccionario y Calendario en el editor de carga de datos.

Si ha añadido datos utilizando Añadir datos, tendrá una sección en el script de carga de datos denominada
Sección generada automáticamente que contiene el código de script requerido para cargar los datos.

Crear una nueva sección de script


Podemos insertar nuevas secciones de script para organizar nuestro código.

Haga lo siguiente:

l Haga clic en P .

La nueva sección se inserta tras la sección actualmente seleccionada.

Eliminar una sección de script


Podemos eliminar una sección de script, incluido todo el código de la sección.

Eliminar una sección de script es una acción que no se puede deshacer.

Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 126


4   Cargar datos con el script de carga de datos

l Haga clic en E junto a la pestaña de sección para borrarla. Se le pedirá confirmación antes de
eliminarla.
Ahora se ha eliminado la sección.

Renombrar una sección de script


Podemos renombrar una sección de script.

Haga lo siguiente:

1. Haga clic en el nombre de la sección e introduzca el nombre.


2. Pulse Enter o haga clic fuera de la sección cuando haya terminado.

Ahora se ha renombrado la sección.

Reubicar secciones de script


Podemos reorganizar el orden de las secciones para modificar el orden de la ejecución del script.

Haga lo siguiente:

1. Seleccione la sección que desee mover.


2. Coloque el cursor sobre las barras de arrastre o y arrastre la sección para reorganizar el orden.

Ahora se han reorganizado las secciones.

Depurar el script de carga de datos


Puede utilizar las capacidades de depuración del Editor de carga de datos para avanzar por la ejecución de su
script mediante unos puntos de interrupción, que le permitirán inspeccionar los valores de las variables y el
resultado de la ejecución del script. Puede seleccionar si desea ver una o todas las opciones: Salida, Variables y
Puntos de Interrupción.

Para mostrar el panel de depuración, haga lo siguiente:

l Haga clic en u en la barra de herramientas del Editor de carga de datos.


El panel de depuración se abre en la parte inferior del Editor de carga de datos.

No podrá crear conexiones, editar conexiones, seleccionar datos, guardar el script o cargar datos
mientras se encuentre en el modo de depuración. El modo de depuración comienza con la
ejecución del depurador y continúa hasta que el script se ha ejecutado o la ejecución ha terminado.

Barra de herramientas de depuración


El panel de depuración del Editor de carga de datos contiene una barra de herramientas con las siguientes
opciones para controlar la ejecución del depurador:

Gestión de datos - Qlik Sense, June 2019 127


4   Cargar datos con el script de carga de datos

Opciones de la barra de herramientas del depurador


Elemento
Descripción
de IU

Carga Habilítelo para limitar cuántas filas de datos cargar desde cada fuente de datos. Esto viene bien
limitada para reducir el tiempo de ejecución si sus fuentes de datos son muy extensas.

Introduzca el número de filas que desee cargar.

Esto solo se aplica a los orígenes de datos físicos. Por ejemplo, las cargas Inline y las
generadas automáticamente no se limitarán.

œ Inicie o continúe la ejecución en modo de depuración hasta que se alcance el siguiente punto de
interrupción.

Œ Pase a la siguiente línea de código.

– Finalice la ejecución aquí. Si termina antes de que se haya ejecutado todo el código, el modelo
de datos resultante solo contendrá datos hasta la línea de código en la que finalizó la ejecución.

Salida
Salida muestra todos los mensajes de salida que se generan durante la ejecución del depurador. Puede
seleccionar bloquear el resultado del desplazamiento cuando se muestran nuevos mensajes haciendo clic en \ .

Además, el menú de salida (¨ ) contiene las siguientes opciones:

Opciones del menú Salida


Elemento de IU Descripción

Borrar Haga clic en esta opción para eliminar todos los mensajes de salida.

Seleccionar todo el texto Haga clic en esta opción para seleccionar todos los mensajes de salida.

Desplazarse hacia el final Haga clic en esto opción para desplazarse hasta el último mensaje de salida.

Variables
Variables muestra todas las variables reservadas, variables de sistema y variables definidas en el script, y
muestra los valores actuales durante la ejecución de script.

Establecer una variable como favorita


Si desea inspeccionar variables específicas durante la ejecución, puede establecerlas como favoritas. Las
variables favoritas se muestran en la parte superior de la lista de variables y se marcan con una estrella
amarilla. Para establecer una variable como favorita, haga lo siguiente:

l Haga clic en ï junto a la variable.


La ï ahora está de color amarillo y la variable se mueve a la parte superior de la lista de variables.

Gestión de datos - Qlik Sense, June 2019 128


4   Cargar datos con el script de carga de datos

Variables de filtrado
Puede aplicar un filtro para mostrar solo un tipo seleccionado de variables usando las siguientes opciones del
menú de variables (¨ ):

Opciones del menú Variables


Elemento de IU Descripción

Mostrar todas las variables Haga clic aquí para que se muestren todos los tipos de variables.

Mostrar variables de sistema Haga clic aquí para que se muestren las variables de sistema.

Las variables de sistema están definidas por Qlik Sense, pero se puede
cambiar el valor de la variable en el script.

Mostrar variables reservadas Haga clic aquí para que se muestren las variables reservadas.

Las variables reservadas están definidas por Qlik Sense y su valor no se


puede cambiar.

Mostrar las variables Haga clic aquí para que se muestren las variables definidas por el
definidas por el usuario usuario.

Las variables definidas por el usuario son variables que ha definido en el


script.

Puntos de interrupción
Puede añadir puntos de interrupción a su script para poder detener la ejecución del depurador en determinadas
líneas de código e inspeccionar los valores de las variables y los mensajes de salida en este punto. Cuando llegue
a un punto de interrupción, puede escoger detener la ejecución de script, continuar hasta el siguiente punto de
interrupción o avanzar hasta la siguiente línea de código. Todos los puntos de interrupción van numerados en el
script, con una referencia de sección y número de línea.

Añadir un punto de interrupción


Para añadir un punto de interrupción en una línea de código, realice una de las acciones siguientes:

l En el script, haga clic directamente en el área a la derecha del número de línea donde desee añadir el
punto de interrupción.
Una Q junto al número de línea indicará que hay un punto de interrupción en esta línea.

Se pueden añadir puntos de interrupción incluso cuando se ha cerrado el panel de depuración.

Eliminar puntos de interrupción


Puede eliminar un punto de interrupción eligiendo una de las siguientes opciones:

l En el script, haga clic en Q junto al número de línea.


l En la lista de puntos de interrupción, haga clic en E , junto a un punto de interrupción.

Gestión de datos - Qlik Sense, June 2019 129


4   Cargar datos con el script de carga de datos

También puede hacer clic en ¨ y seleccionar Eliminar todos para eliminar todos los puntos de interrupción
del script.

Habilitar y deshabilitar los puntos de interrupción


Cuando crea un punto de interrupción, se habilita de forma predeterminada por m junto al siguiente punto de
interrupción en la lista de puntos de interrupción. Puede habilitar y deshabilitar puntos de interrupción
individuales seleccionando y deseleccionándolos en la lista de puntos de interrupción.

También tiene las siguientes opciones en el menú de puntos de interrupción (¨ ):

l Habilitar todos
l Deshabilitar todos

Guardar el script de carga


Cuando guardamos un script se guarda la app completa, pero los datos no se recargan de forma automática.

El editor de carga de datos guarda su trabajo automáticamente a medida que realiza cambios en su script de
carga. Puede forzar un guardado pulsando CTRL+S.

El script se ha guardado, pero la app aún contendrá los datos antiguos de la anterior recarga, lo cual se indica
en la barra de herramientas. Si desea actualizar la app con los nuevos datos, haga clic en Cargar datos° en
la barra de herramientas del editor de carga de datos.

Cuando guardamos un script, se verifican automáticamente los errores de sintaxis. Los errores de sintaxis se
destacan en el código, y todas las secciones del script que contienen errores de sintaxis se indican mediante una
ù junto a la etiqueta de sección.

El script se guarda automáticamente en la app al cargar los datos.

Ejecutar el script para cargar datos


Haga clic en Cargar datos° en la barra de herramientas para ejecutar el script y volver a cargar los datos en
la app. La app se guarda automáticamente antes de cargar los datos.

Aparece el cuadro de diálogo Progreso de carga de datos y puede Cancelar la carga. Una vez finalizada la
carga de datos, el cuadro de diálogo se actualiza con el estado (Completado o Fallido) y aparece un resumen
de los posibles errores y advertencias, como las claves sintéticas. El resumen también se muestra en Salida, por
si desea verlo después de que se haya cerrado el cuadro de diálogo.

Si desea que el cuadro de diálogo Progreso de carga de datos se cierre siempre automáticamente
tras completar la ejecución, seleccione Cerrar al terminar.

Gestión de datos - Qlik Sense, June 2019 130


4   Cargar datos con el script de carga de datos

Métodos abreviados de teclado en el Editor de carga de datos


Hay una serie de métodos abreviados de teclado que podemos utilizar para trabajar con mayor eficacia y
facilidad en el entorno del Editor de carga de datos.

Métodos abreviados de teclado

A continuación se detallan los métodos abreviados de teclado teniendo en cuenta que está
trabajando en Windows. Para Mac OS use Cmd en vez de Ctrl.

Métodos abreviados de teclado en el Editor de carga de datos


Acceso rápido Acción

Esc en el campo de Cierra el campo de introducción de la cadena de búsqueda.


buscar o reemplazar

Alt+F5 Muestra las herramientas del depurador o las oculta si están visibles.

Alt+F6 Ejecuta la depuración si la herramienta de depuración está activa.

Alt+F7 Continúa con el siguiente paso en el depurador si la herramienta de depuración está


activa.

Alt+F8 Detiene el depurador si la herramienta de depuración está activa.

F9 Alterna entre inserción y eliminación de un punto de interrupción en el depurador.

Alt+F9 Muestra el panel izquierdo o lo oculta, si está visible.

Alt+F10 Muestra el panel derecho o lo oculta, si está visible.

Alt+F11 Expande el editor de script a pantalla completa.

Alt+1 Muestra el panel de salida o lo oculta si está visible.

Alt+2 Muestra el panel de Variables o lo oculta si está visible, si la herramienta de


depuración está activa.

Alt+3 Muestra el panel de Puntos de interrupción o lo oculta si está visible, si la


herramienta de depuración está activa.

Ctrl+0,Ctrl+0 Genera datos de muestra.

Pestaña Sangra (o indenta) una línea en el script.

Mayús+Tab Elimina el sangrado (o indentado) de una línea en el script.

CTRL+P Imprime la vista actual o la hoja/historia activa.

CTRL+S Guarda los cambios.

Ctrl+F Muestra el campo de introducción de la búsqueda o lo oculta si está abierto.

CTRL+H Abre la ayuda en línea en el contexto de la función seleccionada actual, mientras


está en el editor de carga de datos o en el editor de expresiones.

Gestión de datos - Qlik Sense, June 2019 131


4   Cargar datos con el script de carga de datos

Acceso rápido Acción

CTRL+K Alterna entre la inserción y eliminación de una línea de comentario de código.

Intro/Retorno en el Busca la siguiente instancia de la cadena de búsqueda.


campo de búsqueda

Intro/Retorno en el Reemplaza la instancia seleccionada de la cadena de búsqueda.


campo reemplazar

CTRL-mayús- Recarga los datos.


Intro/Retorno

CTRL+Z Deshacer acción. Se repite para ir deshaciendo acciones anteriores.

CTRL+X Corta el elemento seleccionado y lo copia en el portapapeles. Cuando se utiliza el


navegador Google Chrome: si el cursor se coloca frente a una fila en el editor de
carga de datos o en el editor de expresiones, sin seleccionar nada, se corta toda la
fila.

CTRL+C Copia el elemento seleccionado al portapapeles.

CTRL+V Pega el último elemento copiado que hay en el portapapeles.

CTRL+espacio Completa automáticamente la cadena de autotexto.

CTRL+mayús+espacio Muestra la información de una herramienta. (No compatible en Qlik Sense Desktop)

Alt+Insertar Inserta una nueva sección en el script.

Alt+AvPág Navega hasta la sección anterior.

Alt+RePág Navega hasta la siguiente sección.

4.3 Entender la sintaxis de script y las estructuras de datos


Extraer, transformar y cargar
En general, la forma de cargar datos en la app se puede explicar mediante los procesos de extracción,
transformación y carga:

l Extraer
El primer paso consiste en extraer datos del sistema de origen de datos. En un script, se utilizan las
sentencias SELECT o LOAD para definir esto. Las diferencias entre estas sentencias son las siguientes:
l SELECT sirve para seleccionar datos desde una fuente de datos ODBC o proveedor de OLE DB. La
sentencia SELECT SQL la evalúa el proveedor de datos y no Qlik Sense.
l La sentencia LOAD carga datos desde un archivo, desde datos definidos en el script, desde una
tabla previamente cargada, desde una página web, desde el resultado de una sentencia SELECT
posterior, o bien generando los datos automáticamente.
l Transformar
La etapa de transformación consiste en la manipulación de los datos mediante las funciones de script y
las reglas para derivar la estructura deseada del modelo de datos. Las operaciones habituales son:

Gestión de datos - Qlik Sense, June 2019 132


4   Cargar datos con el script de carga de datos

l Calcular nuevos valores


l Traducir los valores codificados
l Renombrar campos
l Unir tablas
l Agregar los valores
l Pivotar
l Validar los datos
l Cargar
En el paso final, se ejecuta el script para cargar el modelo de datos que se ha definido en la app.

El objetivo debería ser crear un modelo de datos que permita una manipulación eficaz de los datos en Qlik
Sense. Por lo general esto significa que deberíamos buscar un esquema de estrella razonablemente
normalizado o un esquema en copo de nieve sin referencias circulares, esto es, un modelo en el que cada
entidad se almacena en una tabla aparte. En otras palabras, un modelo de datos típico presentaría el siguiente
aspecto:

l Una tabla de hechos central que contiene claves a las dimensiones y los números utilizados para calcular
medidas (como número de unidades, cifras de ventas y cifras de presupuestos).
l Unas tablas secundarias alrededor conteniendo las dimensiones con todos sus atributos (como
productos, clientes, categorías, calendario y proveedores).

En muchos casos es posible resolver una tarea, por ejemplo agregaciones, bien creando un modelo
de datos más rico o bien realizando las agregaciones en las expresiones del gráfico. Como regla
general, experimentará un mejor rendimiento si mantiene las funciones de transformación de datos
en el script de carga.

Es una buena práctica escribir primero un boceto del modelo de datos en papel. Esto le ayudará a
estructurar qué datos extraer y qué transformaciones efectuar.

Sentencias de carga de datos


Los datos se cargan mediante sentencias LOAD o SELECT. Cada una de estas sentencias genera una tabla
interna. Una tabla siempre se puede considerar como un listado de algo, cada registro (fila) es por tanto una
nueva instancia del tipo de objeto y cada campo (columna) un atributo específico o una propiedad del objeto.

Las diferencias entre estas sentencias son las siguientes:

l SELECT sirve para seleccionar datos desde una fuente de datos ODBC o proveedor de OLE DB. La
sentencia SELECT SQL la evalúa el proveedor de datos y no Qlik Sense.
l La sentencia LOAD carga datos desde un archivo, desde datos definidos en el script, desde una tabla
previamente cargada, desde una página web, desde el resultado de una sentencia SELECT posterior, o
bien generando los datos automáticamente.

Gestión de datos - Qlik Sense, June 2019 133


4   Cargar datos con el script de carga de datos

Reglas:
Tenga en cuenta las siguientes reglas cuando vaya a cargar datos en Qlik Sense:

l Qlik Sense no distingue entre las tablas generadas por una sentencia LOAD o SELECT. Esto significa que,
al cargar varias tablas, no importa si se cargan mediante sentencias LOAD o SELECT o una
combinación de ambas.
l El orden de los campos en la sentencia o en la tabla original de la base de datos es indiferente para la
lógica de Qlik Sense.
l Los nombres de los campos se utilizan en el proceso posterior para identificar los campos y establecer
asociaciones. Los nombres distinguen entre mayúsculas y minúsculas, por eso en muchas ocasiones
habrá que cambiarlos de nombre en el script.

Ejecución de script
Por lo general, el orden de eventos de una típica sentencia LOAD o SELECT es el siguiente:

1. Evaluación de las expresiones


2. Renombrado de campos por as
3. Renombrado de campos por alias
4. Cualificar los nombres de campos
5. Enlazar datos en nombres de campo que coinciden
6. Almacenar los datos en una tabla interna

Campos
Los campos son las entidades primarias de almacenamiento de datos en Qlik Sense. Un campo normalmente
contiene una serie de valores, denominados valores de campo. En la terminología de las bases de datos se dice
que los datos procesados por Qlik Sense proceden de los archivos de datos. Un archivo se compone de varios
campos donde cada entrada de datos constituye un registro. Los términos archivo, campo y registro son
equivalentes a tabla, columna y fila respectivamente. La lógica AQL de Qlik Sense funciona únicamente en los
campos y sus valores de campo.

Los datos de campo son recuperados por el script mediante sentencias LOAD, SELECT o Binary. La única
manera de modificar los datos de un campo es ejecutando de nuevo el script. Los valores de campo reales no
pueden ser manipulados por el usuario desde el diseño ni por medio de la Automatización. Una vez leídos en
Qlik Sense, solo pueden visualizarse y emplearse para selecciones lógicas y cálculos.

Los valores de campo consisten en datos numéricos o alfanuméricos (texto). Los valores numéricos en realidad
tienen dos valores, el valor numérico actual y su representación de texto con formato. En los objetos de hoja
solo se muestra este último.

El contenido de un campo se puede representar en un panel de filtrado.

Gestión de datos - Qlik Sense, June 2019 134


4   Cargar datos con el script de carga de datos

Campos derivados
Si tenemos un grupo de campos que están relacionados, o si los campos portan información que puede
desglosarse en partes más pequeñas útiles para crear dimensiones o medidas, podemos crear definiciones de
campos que sirvan para generar campos derivados. Un ejemplo de esto es un campo de fecha, desde el que
podemos derivar múltiples atributos, como por ej. año, mes, número de semana o día de la semana. Todos
estos atributos pueden calcularse en una expresión de dimensión empleando funciones de fecha de Qlik Sense,
pero una alternativa es crear una definición de calendario que sea común para todos los campos del tipo fecha.
Las definiciones de campo se almacenan en el script de carga de datos.

Las definiciones de campos de calendario predeterminadas para Qlik Sense se incluyen en


autoCalendar para campos de fecha cargados usando el Gestor de datos. Para más información,
vea Añadir datos a la app (page 16).

Declarar las definiciones de campos de calendario


Utilizamos la sentencia Declare para crear una definición de los campos derivados. Aquí es donde definimos los
distintos atributos del campo, en este caso atributos relacionados. Cada campo se describe como
<expression> As field_name tagged tag. Configurar una o más etiquetas es opcional, pero puede afectar a la
ordenación del campo derivado. Utilice $1 para hacer referencia al campo de datos desde el que se deben
generar los campos derivados.

No utilice autoCalendar como nombre para las definiciones de campos de calendario, ya que este
nombre se reserva para las plantillas de calendario generadas automáticamente.

Calendar:
DECLARE FIELD DEFINITION TAGGED '$date'
Parameters
first_month_of_year = 1
Fields
Year($1) As Year Tagged ('$numeric'),
Month($1) as Month Tagged ('$numeric'),
Date($1) as Date Tagged ('$date'),
Week($1) as Week Tagged ('$numeric'),
Weekday($1) as Weekday Tagged ('$numeric'),
DayNumberOfYear($1, first_month_of_year) as DayNumberOfYear Tagged ('$numeric')
Groups
Year, Week, Weekday type drilldown as YearWeekDayName,
Year, Month, Date type collection as YearMonthDate;

Enlazar campos de datos de mapas con el calendario mediante Derive


El siguiente paso es utilizar la sentencia Derive para enlazar campos de datos previos con el calendario. Esto
creará los campos derivados. Podemos hacer esto de tres maneras distintas en el script de carga de datos.

l Asociar campos específicos por nombre de campo.


DERIVE FIELDS FROM FIELDS OrderDate,ShippingDate USING Calendar;

Gestión de datos - Qlik Sense, June 2019 135


4   Cargar datos con el script de carga de datos

l Asociar todos los campos que contengan una o más etiquetas de campo específicas.
DERIVE FIELDS FROM EXPLICIT TAGS '$date' USING Calendar;

l Asociar todos los campos que están etiquetados con una de las etiquetas de la definición de campo
($date en el ejemplo anterior).
DERIVE FIELDS FROM IMPLICIT TAG USING Calendar;

En este caso podría utilizar cualquiera de los tres ejemplos aquí presentados.

Usar los campos de fecha derivados en una visualización


Qlik Sense está preparado para reconocer campos de fecha derivados si hemos creado una definición de
calendario y asociado los campos como en este ejemplo. Están disponibles en la sección Campos fecha y hora
del panel de activos Campos. También encontrará todos los campos derivados en el editor de expresiones y
cuando cree o edite dimensiones.

Etiquetas de campo
Las etiquetas de campo ofrecen la posibilidad de añadir metadatos a los campos de su modelo de datos. Hay
dos tipos de etiquetas de campo:

l Etiquetas de campo de sistema


Las etiquetas de campo de sistema se generan automáticamente cuando se ejecuta el script y los datos
se cargan. Algunas de las etiquetas pueden manipularse en el script. Las etiquetas de sistema siempre
van precedidas de un signo $.
l Etiquetas de campo personalizadas
Podemos añadir etiquetas de campo personalizadas a campos en el script de carga de datos, usando la
sentencia Tag. Las etiquetas personalizadas pueden tener nombres distintos a los de las etiquetas de
sistema.

Etiquetas de campo de sistema


Las siguientes etiquetas de sistema se generan automáticamente al cargar los datos.

Etiquetas de campo de sistema


Puede
Etiqueta Descripción manipularse
en el script

$system Campo de sistema generado por Qlik Sense durante la ejecución de No


script.

$key Campo clave que proporciona un enlace entre dos o más tablas. No

$keypart El campo forma parte de una o más claves sintéticas. No

$syn Clave sintética No

Gestión de datos - Qlik Sense, June 2019 136


4   Cargar datos con el script de carga de datos

Puede
Etiqueta Descripción manipularse
en el script

$hidden Campo oculto, esto es, no mostrado en ninguna lista de selección al Sí


crear las visualizaciones, dimensiones o medidas. Se pueden utilizar
campos ocultos en las expresiones, pero debemos especificar el nombre
del campo.

Mediante las variables de sistema HidePrefix y HideSuffix


determinamos qué campos serán ocultos.

$numeric Todos los valores del campo (que no sean NULL) son numéricos. Sí

$integer Todos los valores del campo (que no sean NULL) son enteros. Sí

$text Ninguno de los valores del campo son numéricos. Sí

$ascii Los valores del campo contienen únicamente caracteres ASCII estándar. Sí

$date Todos los valores del campo (que no sean NULL) se pueden interpretar Sí
como fechas (enteros).

$timestamp Todos los valores del campo (que no sean NULL) se pueden interpretar Sí
como marcas de fecha-hora.

$geoname Los valores de campo contienen nombres de ubicaciones geográficas, Sí


relacionadas con un campo de puntos ($geopoint) y/o un campo de
área ($geomultipolygon).

$geopoint Los valores de campo contienen datos de puntos de geometría que Sí


representan puntos en un mapa en el formato [longitud, latitud].

$geomultipolygon Los valores de campo contienen datos poligonales geométricos, que Sí


representan áreas de un mapa.

Etiquetas de campo derivadas


Las etiquetas siguientes se pueden utilizar cuando declaramos campos derivados para especificar cómo usar y
mostrar los campos en un eje contiguo en un gráfico de líneas. Podemos manipular las etiquetas en el script de
carga de datos.

Etiquetas de campo derivadas


Etiqueta Descripción

$axis La etiqueta $axis se usa para especificar que el campo debe generar una marca de verificación
en el eje contiguo del gráfico.

Gestión de datos - Qlik Sense, June 2019 137


4   Cargar datos con el script de carga de datos

Etiqueta Descripción

$qualified Puede especificar una versión cualificada y otra simplificada de una etiqueta de un eje
derivando dos campos distintos. El campo cualificado se muestra como una etiqueta cuando se
$simplified
acerca el eje con el zoom hasta un nivel más profundo, para mostrar todo el contexto.

Por ejemplo, puede generar dos campos cuando muestre los datos por trimestre:

Un campo simplificado, con la etiqueta $simplified mostrando el trimestre, como "Q1" y un


campo cualificado, con la etiqueta $qualified, mostrando el año y el trimestre, como "2016-Q1".

Cuando nos alejamos del eje de tiempo con el zoom, el eje muestra las etiquetas en dos niveles,
para el año (2016) y el trimestre (Q1), usando el campo simplificado. Cuando nos acercamos
con el zoom, el eje muestra las etiquetas de trimestre y mes, y el campo cualificado (2016-Q1) se
utiliza para ofrecer un contexto completo anual para el trimestre.

$cyclic La etiqueta $cyclic se utiliza para campos cíclicos, por ejemplo, trimestre o mes, con una
representación doble de los datos.

Campos de sistema
Además de los campos que se extraen de la fuente de datos, los campos de sistema son campos producidos por
Qlik Sense. Todos ellos comienzan con un "$" y pueden mostrarse como campos normales en una visualización,
como un panel de filtrado o una tabla. Los campos de sistema se crean automáticamente cuando cargamos
datos y se utilizan principalmente como ayuda para el diseño de una app.

Campos de sistema disponibles


Están disponibles los siguientes campos de sistema:

Campos de sistema disponibles


Campo de sistema Descripción

$Table Contiene todas las tablas que se cargan.

$Field Contiene todos los campos de las tablas que se cargan.

$Fields Contiene el número de campos de cada tabla.

$FieldNo Contiene la posición de los campos en las tablas.

$Rows Contiene el número de filas en las tablas.

Ninguno de los campos de sistema puede manipularse en el script.

Utilizar campos de sistema en una visualización


Los datos de los campos de sistema están asociados. Por ejemplo, si agrega dos paneles de filtrado, uno con
$Table y otro con $Field, si selecciona una tabla, el panel de filtrado $Field mostrará los campos en la tabla
seleccionada como valores posibles.

Gestión de datos - Qlik Sense, June 2019 138


4   Cargar datos con el script de carga de datos

Los campos de sistema no se incluyen en las listas de campos en el panel de activos. Se incluyen en el editor de
expresiones. Si desea utilizar un campo de sistema en el panel de activos necesita referenciarlo introduciéndolo
manualmente.

Example: En una dimensión en el panel de activos

=$Field

Renombrar campos
A veces es necesario renombrar campos para obtener las asociaciones deseadas. Las tres razones principales
para renombrar campos son:

l Dos campos tienen distintos nombres, pero denotan una misma cosa:
l El campo ID en la tabla Customers
l El campo CustomerID en la tabla Orders
Los dos campos denotan un código de identificación de cliente específico y ambos deben tener el mismo
nombre, por ejemplo, CustomerID.
l Dos campos tienen idéntico nombre, pero denotan cosas distintas:
l El campo Date en la tabla Invoices
l El campo Date en la tabla Orders
Los dos campos deben ser renombrados, por ejemplo, InvoiceDate y OrderDate.

l También podría ocurrir que hubiera errores de ortografía o escritura en la base de datos, o diferentes
convenciones en cuanto al uso de mayúsculas o minúsculas.

Los campos pueden renombrarse en el script, no hace falta modificar los datos originales. Hay dos formas
distintas de renombrar los campos, como se muestra en los ejemplos.

Example 1: Usar la sentencia alias

La sentencia LOAD o SELECT puede ir precedida de una sentencia alias.

Alias ID as CustomerID;
LOAD * from Customer.csv;

Example 2: Usar el especificador as

La sentencia LOAD o SELECT puede contener el especificador as.

LOAD ID as CustomerID, Name, Address, Zip, City, State from Customer.csv;

Tablas lógicas
Cada sentencia LOAD o SELECT genera una tabla. Normalmente, Qlik Sense trata el resultado de cada una de
ellas como una tabla lógica. Sin embargo, hay un par de excepciones a esta regla:

l Si dos o más sentencias dan como resultado tablas con idénticos nombres de campo, las tablas serán
concatenadas y tratadas como una tabla lógica.

Gestión de datos - Qlik Sense, June 2019 139


4   Cargar datos con el script de carga de datos

l Si una sentencia LOAD o SELECT va precedida de cualquiera de los siguientes cualificadores, los datos se
alteran o se tratan de forma distinta.

Tablas lógicas
Tabla Descripción

concatenate Esta tabla está concatenada con (unida a) otra tabla designada ya existente, o con la última
tabla lógica creada.

crosstable Esta tabla no está pivotada. Es decir, se convierte del formato de tabla cruzada al formato
de columnas.

generic Esta tabla se divide en otras muchas tablas lógicas.

info Esta tabla no se carga como una tabla lógica, sino como una tabla de información que
contiene enlaces a información externa, como archivos, sonidos, URL, etc.

intervalmatch La tabla (que debe contener exactamente dos columnas) se interpreta como intervalos
numéricos, los cuales están asociados con números discretos en un campo especificado.

join Esta tabla va unida por Qlik Sense con otra ya existente o con la última tabla lógica creada,
a través de sus campos en común.

keep Esta tabla se reduce a los campos en común con otra tabla designada ya existente, o con la
última tabla lógica creada.

mapping Esta tabla (que debe contener exactamente dos columnas) se lee como una tabla de enlace,
la cual no se asocia nunca a otras tablas.

semantic Esta tabla no se carga como una tabla lógica, sino como una tabla semántica, la cual
contiene relaciones que no deberían unirse, por ej. predecesor, sucesor y otras referencias a
otros objetos del mismo tipo.

Las tablas lógicas se asocian cuando los datos se han cargado.

Nombres de tabla
A las tablas de Qlik Sense se les pone el nombre al almacenarlas en la base de datos interna de Qlik Sense. Los
nombres de tabla se pueden usar, por ejemplo, para sentencias LOAD con una cláusula resident o con
expresiones que contienen la función peek, y se pueden ver en el campo de sistema $Table en el diseño.

Se asigna un nombre a una tabla siguiendo estas reglas:

1. Si una etiqueta precede inmediatamente a una sentencia LOAD o SELECT, la etiqueta se utiliza como
nombre de tabla. La etiqueta debe ir seguida de dos puntos ":".

Example:

Table1:
LOAD a,b from c.csv;

Gestión de datos - Qlik Sense, June 2019 140


4   Cargar datos con el script de carga de datos

2. Si no se proporciona una etiqueta, se utiliza el nombre del archivo o el nombre de la tabla


inmediatamente posterior a la palabra clave FROM en la sentencia LOAD o SELECT. Se permite un
máximo de 32 caracteres. La extensión se omite si se usa el nombre del archivo.
3. Las tablas cargadas inline se denominan INLINExx, donde xx es un número. La primera tabla inline
recibirá el nombre INLINE01.
4. Las tablas generadas automáticamente se denominan AUTOGENERATExx, donde xx es un número. La
primera tabla generada automáticamente recibe el nombre AUTOGENERATE01.
5. Si un nombre de tabla generado conforme a las reglas aquí descritas estuviera en conflicto con un
nombre de tabla anterior, el nombre recibirá la extensión -x , donde x es un número. Este número se
incrementa hasta quedar libre de conflictos. Por ejemplo, tres tablas podrían llamarse Budget, Budget-1
y Budget-2.

Hay tres dominios distintos para los nombres de tablas: section access, section application y tablas de
correspondencia o enlace. Los nombres de tabla generados en section access y section application se tratan
por separado. Si un nombre de tabla mencionado no se encuentra en la sección en cuestión, Qlik Sense lo
buscará también en las otras secciones. Las tablas de correspondencia se gestionan individualmente y no tienen
absolutamente ninguna conexión con los otros dos dominios de los nombres de tabla.

Etiquetas de tabla
Una tabla se puede etiquetar para referencia posterior, por ejemplo, mediante una sentencia LOAD con una
cláusula resident o con expresiones que contengan la función peek. La etiqueta, que puede ser una cadena
arbitraria de números o caracteres, deberá preceder a la primera o segunda sentencia LOAD o SELECT que
crea la tabla. La etiqueta debe ir seguida de dos puntos " :".

Las etiquetas que contengan espacios en blanco deben citarse empleando comillas simples o dobles o corchetes.

Example 1:

Table1:
LOAD a,b from c.csv;
LOAD x,y from d.csv where x=peek('a',y,'Table1');

Example 2: Etiqueta de tabla con un espacio en blanco

[All Transactions]:
SELECT * from Transtable;
LOAD Month, sum(Sales) resident [All Transactions] group by Month;

Asociaciones entre tablas lógicas


Una base de datos puede contener muchas tablas. Cada tabla puede considerarse como una lista de algo; cada
registro de la lista representa una instancia de un objeto de algún tipo.

Example:

Si dos tablas son listados de cosas distintas, por ejemplo, si una es una lista de clientes y otra una lista de
facturas y ambas tablas tienen un campo en común, como puede ser el número de cliente, en general podemos
decir que existe una relación entre ambas tablas. En las herramientas SQL estándar de consulta, las dos tablas

Gestión de datos - Qlik Sense, June 2019 141


4   Cargar datos con el script de carga de datos

siempre deberían ir unidas.

Las tablas definidas en el script de Qlik Sense se denominan tablas lógicas. Qlik Sense efectúa asociaciones entre
las tablas basándose en los nombres de campo y lleva a cabo las uniones cuando se realiza una selección, por
ejemplo, cuando el usuario selecciona un valor de campo en un filtro.

Esto significa que una asociación es casi lo mismo que una unión mediante ‘join’. La única diferencia está en
que la unión join se efectúa al ejecutarse el script y la tabla lógica es normalmente el resultado del join. La
asociación se realiza tras crearse la tabla lógica, las asociaciones siempre se realizan entre tablas lógicas.

Cuatro tablas: una lista de países, una lista de clientes, una lista de transacciones y una lista de suscripciones, que están
asociadas entre sí a través de los campos Country y CustomerID.

Asociación de Qlik Sense comparada con un join natural externo (outer join) de SQL
Un asociación de Qlik Sense se parece a un join natural externo (outer join) de SQL. Sin embargo, la asociación
es más general: un outer join en SQL suele ser una proyección unidireccional de una tabla en otra. Una
asociación siempre da como resultado un natural outer join completo (bidireccional).

Información de frecuencia al asociar campos


Existen algunas limitaciones en cuanto al uso de la mayoría de campos de asociación, es decir, en campos que
son comunes a dos o más tablas. Cuando un campo aparece en más de una tabla, Qlik Sense se enfrenta al
problema de tener que saber cuál de las tablas debe utilizar para calcular las frecuencias de datos.

Qlik Sense analiza los datos para ver si existe alguna forma no ambigua de identificar una tabla principal en la
que contar (a veces existe), pero en la mayoría de los casos el programa solo puede hacer una suposición. Dado
que una suposición errónea podría ser fatal (Qlik Sense daría la impresión de cometer errores en los cálculos), el
programa ha sido diseñado de tal manera que no permite determinadas operaciones cuando la interpretación
de los datos es ambigua para campos asociados.

Gestión de datos - Qlik Sense, June 2019 142


4   Cargar datos con el script de carga de datos

Limitaciones en la asociación de campos


1. En un panel de filtrado que muestre el campo, no se podrá visualizar la información de frecuencia.
2. Los cuadros de estadísticas del campo muestran n/a para la mayoría de entidades estadísticas.
3. En los gráficos, no es posible crear expresiones que contengan funciones que dependan de la
información de frecuencia (como las funciones Sum, Count y Average) en el campo, a menos que se
active el modificador Distinct. Después de cada recarga, Qlik Sense analizarán todas las expresiones de
los gráficos para ver si ha aparecido alguna ambigüedad como resultado de los cambios en las
estructuras de los datos. Si el programa encuentra cualquier expresión ambigua, mostrará un diálogo
de advertencia y desactivará esa expresión. La expresión no podrá activarse hasta que no se haya
corregido el problema. Si se activa un archivo de registro, todas las expresiones ambiguas se enumeran
en el registro.

Solución
Hay una manera muy simple de superar estas limitaciones. Cargue el campo una vez más, con un nuevo
nombre, en la tabla donde deba contabilizarse la frecuencia. Utilice a continuación el nuevo campo para un
panel de filtrado con la configuración de frecuencia, para un cuadro de estadísticas o para cálculos en sus
gráficos.

Claves sintéticas
Cuando dos o más tablas de datos tienen dos o más campos en común, esto sugiere una relación de claves
compuestas. Qlik Sense manipula esto creando claves sintéticas automáticamente. Dichas claves son campos
anónimos que representan todas las combinaciones posibles de la clave compuesta.

Si recibe una advertencia sobre las claves sintéticas cuando esté cargando datos, es recomendable revisar la
estructura de datos en el visor del modelo de datos. Pregúntese a sí mismo si el modelo de datos es correcto o
no. A veces lo es pero, a menudo, la clave sintética se encuentra ahí debido a un error en el script.

La presencia de varias claves sintéticas suelen ser un síntoma de un modelo de datos incorrecto, pero no
siempre. Sin embargo, un signo inequívoco de que el modelo de datos es incorrecto es la presencia de claves
sintéticas basadas en otras claves sintéticas.

Cuando el número de claves sintéticas aumenta, en función del volumen de datos, la estructura de
la tabla y otros factores, Qlik Sense puede o no gestionarlas con acierto, y podría terminar
requiriendo demasiado tiempo y/o memoria. En tal caso, será necesario recrear el script
eliminando todas las claves sintéticas.

Tres tablas asociadas con la clave sintética $Syn 1.

Gestión de datos - Qlik Sense, June 2019 143


4   Cargar datos con el script de carga de datos

Gestionar claves sintéticas


Si necesita evitar las claves sintéticas, hay una serie de métodos para solucionar esto en el script de carga de
datos:

l Compruebe que solo se usan como claves los campos que vinculan lógicamente dos tablas.
l Los campos como “Comentario”, “Observación” y “Descripción” pueden estar presentes en
varias tablas sin que exista relación alguna entre ellos y, por tanto, no se deben usar como claves.
l Los campos como “Fecha”, “Compañía” y “Nombre” pueden estar presentes en varias tablas y
tener valores idénticos, pero proporcionar distinta información (Fecha del pedido/Fecha de
envío, Compañía del cliente/Compañía del proveedor). En este tipo de casos no se deben usar
como claves.
l Asegúrese de que no se usan campos redundantes, es decir, asegúrese de que solo se conectan los
campos necesarios. Por ejemplo, si va a usar una fecha como clave, asegúrese de no cargar el “año”, el
“mes” o el “día del mes” de la misma fecha de más de una tabla interna.
l Si fuera necesario, cree sus propias claves no compuestas; esto se suele hacer mediante la
concatenación de cadenas dentro de una función de script AutoNumber.

Entender y resolver las referencias circulares


Si existen referencias circulares ("bucles") en una estructura de datos, las tablas se asociarán de tal forma que
haya más de una ruta de asociaciones entre dos campos.

Por lo general debería evitarse este tipo de estructura de datos en la medida de lo posible, ya que puede llevar
fácilmente a ambigüedades en la interpretación de los datos.

Tres tablas con una referencia circular, ya que hay más de una ruta de asociación entre dos campos.

Gestión de datos - Qlik Sense, June 2019 144


4   Cargar datos con el script de carga de datos

Qlik Sense resuelve el problema de las referencias circulares interrumpiendo el bucle con una tabla
parcialmente desconectada. Si Qlik Sense encuentra estructuras circulares de datos durante la ejecución de un
script de carga, aparecerá un cuadro de diálogo de advertencia y una o varias tablas se definirán como
desconectadas parcialmente. Normalmente, Qlik Sense intenta desconectar la tabla más larga del bucle, ya que
a menudo suele tratarse de una tabla de transacciones que, por regla general, es la que se debe desconectar. En
el visor del modelo de datos, las tablas parcialmente desconectadas se indican mediante líneas discontinuas de
color rojo hacia otras tablas.

Example:

Se cargan los datos procedentes de tres tablas con los siguientes contenidos:

l Los nombres de unos equipos nacionales de fútbol


l Los clubes de fútbol de algunas ciudades
l Las ciudades de algunos países europeos

Vista de las tablas que contienen los datos fuente en Excel.

Esta estructura de datos no es muy buena, ya que el nombre de campo Team se usa con dos fines diferentes:
equipos nacionales y clubes locales. Con estos datos en las tablas la situación lógica que nos encontramos es
imposible de analizar.

Gestión de datos - Qlik Sense, June 2019 145


4   Cargar datos con el script de carga de datos

Cuando se cargan las tablas en Qlik Sense, Qlik Sense determina cuál de las conexiones de datos es la de menor
importancia y desconecta esa tabla.

Abra el Visor del modelo de datos para ver cómo interpreta Qlik Sense la relevancia de las conexiones de
datos:

Vista de las referencias circulares indicadas mediante las líneas de puntos rojos.

La tabla con ciudades y los países a los que pertenecen ahora está parcialmente desconectada con respecto a la
tabla de equipos nacionales de diferentes países y la tabla de clubes locales de distintas ciudades.

Cómo resolver las referencias circulares


Cuando se produzcan referencias circulares, necesitaremos editar el script de carga de datos asignando un
nombre único y diferenciador a uno de los dos campos que posean nombres idénticos.

Haga lo siguiente:

1. Abra el editor de carga de datos.


2. Edite la sentencia LOAD en uno de los nombres de campo duplicados.
En este ejemplo, la sentencia LOAD de la tabla que contiene los equipos locales y sus ciudades incluiría
un nuevo nombre para Team, por ejemplo, LocalClub. La sentencia actualizada LOAD queda así:
LOAD City, Team as LocalClub

3. Haga clic en ° en la barra de herramientas para volver a cargar los datos en la app.

Ahora tenemos una lógica que funciona correctamente en todas las tablas. En este ejemplo, cuando se
selecciona Germany, el equipo nacional, las ciudades alemanas y los clubes locales de cada ciudad se asocian:

Gestión de datos - Qlik Sense, June 2019 146


4   Cargar datos con el script de carga de datos

Cuando abrimos el Visor del modelo de datos, vemos que las conexiones parcialmente desconectadas han
sido reemplazadas por unas conexiones normales:

Concatenar tablas
La concatenación es una operación que combina dos tablas en una sola.

Las dos tablas se añaden simplemente la una a la otra. Es decir, los datos no cambian y la tabla resultante
contiene el mismo número de registros que las dos tablas originales juntas. Se pueden ejecutar secuencialmente
varias operaciones de concatenación y la tabla resultante será la concatenación de más de dos tablas.

Concatenación automática
Si los nombres de los campos y el número de campos de dos o varias tablas cargadas son exactamente iguales,
Qlik Sense concatenará automáticamente el contenido de las diferentes sentencias en una tabla.

Example:

LOAD a, b, c from table1.csv;


LOAD a, c, b from table2.csv;
La tabla interna resultante tiene los campos a, b y c. El número de registros es la suma de los números de
registros de la tabla 1 y la tabla 2.

El número y los nombres de los campos deben ser exactamente iguales. El orden de las dos
sentencias es arbritario.

Concatenación forzada
También se puede hacer que Qlik Sense obligue a concatenar dos o más tablas aunque dichas tablas no tengan
exactamente el mismo conjunto de campos. Esto se hace mediante la inclusión del prefijo concatenate en el
script, el cual concatena una tabla con otra tabla designada o con la última tabla previamente creada.

Example:

LOAD a, b, c from table1.csv;


concatenate LOAD a, c from table2,csv;

La tabla interna resultante tiene los campos a, b y c. El número de registros de la tabla resultante es la suma de
los números de registros de la tabla 1 y la tabla 2. El valor del campo b en los registros que vienen de la tabla 2
es NULL.

Gestión de datos - Qlik Sense, June 2019 147


4   Cargar datos con el script de carga de datos

A menos que se haya especificado el nombre de una tabla previamente cargada en la sentencia
concatenate el prefijo concatenate utiliza la última tabla previamente creada. Por lo tanto, el
orden de las dos sentencias no es arbitrario.

Cómo evitar la concatenación


Si los nombres de los campos y el número de campos de dos o varias tablas cargadas son exactamente iguales,
Qlik Sense concatenará automáticamente el contenido de las diferentes sentencias en una tabla. Esto se puede
evitar con una sentencia noconcatenate. La tabla cargada con la sentencia LOAD o SELECT asociada no se
concatenará entonces con la tabla existente.

Example:

LOAD a, b, c from table1.csv;


noconcatenate LOAD a, b, c from table2.csv;

Cargar datos de una tabla previamente cargada


Hay dos formas de cargar y transformar datos desde una tabla previamente cargada.

l Resident LOAD: usamos el predicado Resident en una sentencia LOAD subsiguiente para cargar una
nueva tabla.
l Load precedente: se carga desde la sentencia LOAD o SELECT precedente sin especificar una fuente.

¿Resident o LOAD precedente ?


En la mayoría de los casos se puede lograr el mismo resultado usando cualquier método. Un LOAD precedente
es generalmente la opción más rápida, pero hay algunos casos en los que necesita usar un Resident LOAD en
su lugar:

l Si desea utilizar la cláusula Order_by para ordenar los registros antes de procesar la sentencia LOAD.
l Si desea utilizar cualquiera de los siguientes prefijos, para los casos en que no se admite LOAD
precedente:
l Crosstable
l Join
l Intervalmatch

Resident LOAD
Puede utilizar el predicado Resident en una sentencia LOAD para cargar datos desde una tabla previamente
cargada. Esto es útil cuando desea realizar cálculos en los datos cargados con una sentencia SELECT donde no
tiene la opción de usar funciones Qlik Sense, como la fecha o el manejo de valores numéricos.

Example:

En este ejemplo, la interpretación de la fecha se realiza en el Resident load, ya que no se puede hacer en el
Crosstable LOAD inicial.

Gestión de datos - Qlik Sense, June 2019 148


4   Cargar datos con el script de carga de datos

PreBudget:
Crosstable (Month, Amount, 1)
LOAD Account,
Jan,
Feb,
Mar,

From Budget;

Budget:
Noconcatenate
LOAD
Account,
Month(Date#(Month,’MMM’)) as Month,
Amount
Resident PreBudget;

Drop Table PreBudget;

Un caso habitual de uso de Resident es cuando desea utilizar una tabla temporal para cálculos o
filtrado. Una vez que haya alcanzado el propósito de la tabla temporal, debe eliminarse utilizando
la sentencia Drop table.

Load precedente
La función load precedente permite cargar una tabla en una sola pasada mientras se conserva la posibilidad de
definir varias transformaciones sucesivas. Básicamente, es una sentencia LOAD que carga desde la sentencia
LOAD o SELECT inferior, sin especificar un cualificador de origen como From o Resident, como se haría
normalmente. Puede apilar cualquier número de sentencias LOAD de esta manera. En primer lugar se evaluará
la sentencia final, luego la sentencia superior, etc., hasta que se haya evaluado la sentencia del principio.

Puede lograr el mismo resultado usando Resident, pero en la mayoría de los casos un LOAD precedente será
más rápido.

Otra ventaja del load precedente es que puede mantener un cálculo en un lugar y reutilizarlo en las sentencias
LOAD situadas encima.

Los siguientes prefijos no pueden usarse junto con un LOAD precedente: Join, Crosstable y
Intervalmatch.

Example 1: Transformar los datos cargados por una sentencia SELECT

Si carga datos de una base de datos utilizando una sentencia SELECT, no puede usar funciones Qlik Sense para
interpretar los datos en la sentencia SELECT. La solución es añadir una sentencia LOAD, donde realice la
transformación de datos, encima de la sentencia SELECT.

En este ejemplo, interpretamos una fecha almacenada como una cadena utilizando la función de Qlik Sense
Date# en una sentencia LOAD, utilizando la sentencia SELECT anterior como fuente.

LOAD Date#(OrderDate,’YYYYMMDD’) as OrderDate;

Gestión de datos - Qlik Sense, June 2019 149


4   Cargar datos con el script de carga de datos

SQL SELECT OrderDate FROM … ;

Example 2: Simplificar el script mediante la reutilización de cálculos

En este ejemplo se usa un cálculo más de una vez en el script:

LOAD ...,
Age( FromDate + IterNo() – 1, BirthDate ) as Age,
Date( FromDate + IterNo() – 1 ) as ReferenceDate
Resident Policies
While IterNo() <= ToDate - FromDate + 1 ;
Introduciendo el cálculo en un primer paso, podemos reutilizarlo en la función Age en un LOAD precedente:

LOAD ..., ReferenceDate,


Age( ReferenceDate, BirthDate ) as Age;
LOAD *,
Date( FromDate + IterNo() – 1 ) as ReferenceDate
Resident Policies
While IterNo() <= ToDate - FromDate + 1 ;

Tipos de datos de Qlik Sense


Qlik Sense puede manipular correctamente cadenas de texto, números, fechas, horas, formatos de fecha-hora y
monedas. Estos se pueden ordenar, mostrar en diversos formatos y utilizar en la realización de cálculos. Esto
significa que, por ejemplo, puede sumar y restar fechas, horas y formatos de fecha/hora.

Representación de datos en Qlik Sense


Para entender la interpretación de datos y los formatos numéricos en Qlik Sense, hay que saber cómo se
almacenan los datos internamente en el programa. Todos los datos cargados en Qlik Sense están disponibles en
dos representaciones: como cadenas o como números.

1. La representación de cadena siempre está disponible y es lo que muestran los cuadros de lista y los
demás objetos de hoja. El formato de los datos en cuadros de lista (formato numérico) solo afecta a la
representación de cadena.
2. La representación numérica solo está disponible si los datos se pueden interpretar como un número
válido. La representación numérica se utiliza para todos los cálculos numéricos y para la ordenación
numérica.

Si existen varios datos con una misma representación numérica dentro de un campo, serán tratados todos
como el mismo valor y compartirán la primera representación de cadena que se encuentre. Ejemplo: Los
números 1,0, 1 y 1.000 leídos en ese orden tendrán todos la representación numérica 1 y la representación inicial
de cadena 1,0.

Interpretación numérica
Al cargar datos que contienen números, monedas o fechas, se interpretarán de manera diferente según si el tipo
de datos está definido o no. Esta sección describe cómo se interpretan los datos en ambos casos.

Gestión de datos - Qlik Sense, June 2019 150


4   Cargar datos con el script de carga de datos

Datos con información de tipo


Los campos que contienen números con un tipo de datos definido en una base de datos cargada usando ODBC
se manejarán por Qlik Sense de acuerdo con sus respectivos formatos. Su representación de cadena será el
número con un formato apropiado aplicado.

Qlik Sense recordará el formato numérico original del campo incluso si se cambia dicho formato numérico
para la medida en los diálogos de Formato numérico del panel de propiedades.

Los formatos predefinidos para los diferentes tipos de datos son:

l entero, números de punto flotante: el parámetro numérico predefinido


l moneda: la configuración predefinida de moneda
l hora, fecha, fecha-hora: Formato ISO estándar

Las configuraciones predefinidas para números y monedas se definen mediante las variables de interpretación
numérica del script o las configuraciones del sistema operativo (Panel de control).

Datos sin información de tipo


Para datos sin información de formato específica de la fuente (por ejemplo, datos de archivos de texto o datos
de ODBC con un formato general), la situación se vuelve más complicada. El resultado final depende de al
menos seis factores:

l La forma en que los datos se han escrito en la base de datos original


l La configuración del sistema operativo para el número, hora, fecha y así sucesivamente. (Panel de
Control)
l El uso de variables opcionales de interpretación numérica en el script
l El uso de funciones opcionales de interpretación en el script
l El uso de funciones opcionales de formato en el script
l Los controles de formato numérico en el documento

Qlik Sense intenta interpretar los datos introducidos como números, fechas, horas, etc. Siempre y cuando se
utilicen las configuraciones predefinidas del sistema en los datos, Qlik Sense realiza la interpretación y la
presentación del formato automáticamente. El usuario no necesita modificar el script ni ninguna otra
configuración en Qlik Sense.

Por defecto, se utiliza el siguiente esquema hasta conseguir una coincidencia completa. (El formato predefinido
es el formato especificado en el sistema operativo, por ejemplo, para el separador decimal, la ordenación entre
año, mes y día, etc. según su definición en el Panel de control o, en algunos casos, mediante las variables
especiales de interpretación numérica del script.

Qlik Sense interpretará los datos de la siguiente manera:

1. Un número de acuerdo con el formato predefinido para números.


2. Una fecha de acuerdo con el formato predefinido para fechas.
3. Una fecha/hora de acuerdo con el formato predefinido para fechas y horas.
4. Una hora de acuerdo con el formato predefinido para horas.

Gestión de datos - Qlik Sense, June 2019 151


4   Cargar datos con el script de carga de datos

5. Una fecha según el siguiente formato: yyyy-MM-dd.


6. Una marca de tiempo de fecha-hora según el siguiente formato: YYYY-MM-DD hh:mm[:ss[.fff]].
7. Una hora según el siguiente formato: hh:mm[:ss[.fff]].
8. Una moneda de acuerdo con el formato predefinido para monedas.
9. Un número con '.' como separador decimal y ',' como separador de miles (siempre que ni el separador
decimal, ni el separador de miles se hayan definido como ',').
10. Un número con ',' como separador decimal y '.' como separador de miles (siempre que ni el separador
decimal, ni el separador de miles se hayan definido como '.').
11. Una cadena de texto. Este dato nunca falla: si los datos son legibles, se puede interpretar siempre como
una cadena de texto.

Al cargar números desde archivos de texto pueden surgir algunos problemas de interpretación, por ejemplo, un
separador decimal o de miles incorrecto puede hacer que Qlik Sense interprete el número de forma incorrecta.
Es conveniente comprobar en primer lugar que las variables de interpretación numérica del script estén
correctamente definidas y que la configuración del sistema en el Panel de control sea adecuada.

Una vez que Qlik Sense haya interpretado los datos como fecha u hora, puede cambiar el formato de fecha u
hora en el panel de propiedades de la visualización.

Puesto que no hay un formato predefinido de datos, es posible que varios registros contengan datos con distinto
formato en un mismo campo. En un campo se pueden encontrar, por ejemplo, fechas, números enteros y texto
válidos. En ese caso, no se aplicará ningún formato a los datos, sino que se mostrarán en su forma original.

Interpretación de fecha y hora


Qlik Sense almacena cada fecha, hora y formato fecha-hora que encuentra en los datos como un número de
serie de la fecha. El número de serie de la fecha se utiliza para fechas, horas y formatos de fecha/hora, y para
los cálculos aritméticos según entidades de fecha y hora. Se pueden sumar y restar las fechas y las horas,
comparar intervalos, etc.

El número de serie de la fecha es el número (valor real) de días transcurridos desde el 30 de diciembre de 1899;
es decir, el formato de Qlik Sense es idéntico al sistema de fechas de 1900 utilizado por Microsoft Excel y otros
programas (en el rango comprendido entre el 1 de marzo de 1900 y el 28 de febrero de 2100). Por ejemplo, 33857
corresponde al 10 de septiembre de 1992. Fuera de este rango, Qlik Sense utiliza el mismo sistema de fecha
ampliado al calendario gregoriano.

Si el campo contiene fechas anteriores al 1 de enero de 1980, el campo no contendrá las etiquetas
del sistema $date o $timestamp. Qlik Sense aún debería reconocer el campo como un campo de
fecha, pero si necesita las etiquetas, puede agregarlas manualmente en el script de carga de datos
mediante la sentencia Tag.

El número de serie para los tiempos es un número entre 0 y 1. El número de serie 0,00000 corresponde a 00:00:00,
mientras que 0,99999 corresponde a 23:59:59. Los números combinados indican fecha y hora: el número de serie
2,5 representa el 1 de enero de 1900 a las 12.00 del mediodía.

Gestión de datos - Qlik Sense, June 2019 152


4   Cargar datos con el script de carga de datos

No obstante, los datos se muestran según el formato de la cadena. De forma predeterminada, se emplean las
configuraciones definidas en el Panel de control. También se puede configurar el formato de los datos a
través de las variables de interpretación numérica del script o con la ayuda de una función de formato. Por
último, también es posible dar nuevo formato a los datos en la hoja de propiedades del objeto de hoja.

Example 1:

l 1997-08-06 se almacena como 35648


l 09:00 se almacena como 0.375
l 1997-08-06 09:00 se almacena como 35648.375

y al contrario:

l 35648 con el formato numérico 'D/M/YY' se muestra como 6/8/97


l 0.375 con el formato numérico 'hh.mm' se muestra como 09.00

Qlik Sense sigue una serie de reglas para tratar de interpretar fechas, horas y otros tipos de datos. No obstante,
el resultado final se verá afectado por una serie de factores, como ya se ha explicado.

Example 2:

Estos ejemplos asumen las siguientes configuraciones predefinidas:

l Separador de números decimales:


l Formato de fecha reducido: YY-MM-DD
l Formato de hora: hh:mm

La tabla siguiente muestra las distintas representaciones cuando los datos se leen en Qlik Sense sin la función
especial de interpretación en el script:

Tabla cuando los datos se leen sin la función de interpretación especial en el script
Interpretación por Formato de Formato de Formato de Formato de
Datos
defecto de Qlik fecha 'YYYY- fecha hora número '#
fuente
Sense MM-DD' 'MM/DD/YYYY' 'hh:mm' ##0.00'

0.375 0.375 1899-12-30 12/30/1899 09:00 0.38

33857 33857 1992-09-10 09/10/1992 00:00 33 857.00

97-08- 97-08-06 1997-08-06 08/06/1997 00:00 35 648.00


06

970806 970806 4557-12-21 12/21/4557 00:00 970 806.00

8/6/97 8/6/97 8/6/97 8/6/97 8/6/97 8/6/97

La tabla siguiente muestra las distintas representaciones cuando los datos se leen en Qlik Sense usando la
función de interpretación date#( A, 'M/D/YY') en el script:

Gestión de datos - Qlik Sense, June 2019 153


4   Cargar datos con el script de carga de datos

Tabla cuando se usa la función de interpretación date#( A, 'M/D/YY') en el script


Interpretación por Formato de Formato de Formato de Formato de
Datos
defecto de Qlik fecha 'YYYY- fecha hora número '#
fuente
Sense MM-DD' 'MM/DD/YYYY' 'hh:mm' ##0.00'

0.375 0.375 0.375 0.375 0.375 0.375

33857 33857 33857 33857 33857 33857

97-08- 97-08-06 97-08-06 97-08-06 97-08-06 97-08-06


06

970806 970806 970806 970806 970806 970806

8/6/97 8/6/97 1997-08-06 08/06/1997 00:00 35 648.00

Expansiones de signo dólar


Las expansiones de signo dólar son definiciones de reemplazos de texto empleados en el script o en las
expresiones. Este proceso es lo que se conoce con el nombre de expansión - incluso si el nuevo texto es más
corto. El reemplazo se efectúa justo antes de evaluar la sentencia de script o la expresión. Técnicamente es una
expansión de macro.

La expansión siempre comienza con '$(' y termina con ')' y el contenido entre corchetes define cómo se realizará
la sustitución del texto. Para evitar la posible confusión con las macros de script en adelante nos referiremos a
las expansiones de macro como expansiones de signo dólar.

Las expansiones de signo dólar pueden usarse con uno de los siguientes:

l variables
l parámetros
l expresiones

Una expansión de signo dólar está limitada en cuanto a la cantidad de expansiones que puede
calcular. Cualquier expansión superior a 1000 niveles de expansiones anidadas no se calculará.

Expansión de signo dólar empleando una variable


Cuando se utiliza una variable para reemplazo de texto en el script o en una expresión, se utiliza la sintaxis
siguiente:

$(variablename)
$(variablename) expande al valor de la variable. Si variablename no existe, la expansión dará como resultado
una cadena vacía.

Para expansiones de variables numéricas se emplea la sintaxis siguiente:

$(#variablename)

Gestión de datos - Qlik Sense, June 2019 154


4   Cargar datos con el script de carga de datos

Siempre produce una representación de decimal válida del valor numérico de la variable, posiblemente con
notación exponencial (para números muy grandes/pequeños). Si variablename no existe o no contiene un valor
numérico, se expandirá a 0 en su lugar.

Example:

SET DecimalSep=',';
LET X = 7/2;
La expansión de signo dólar $(X) se expandirá a 3,5 mientras que $(#X) se expandirá a 3.5.

Example:

Set Mypath=C:\MyDocs\Files\;
...
LOAD * from $(MyPath)abc.csv;
Los datos se cargarán desde C:\MyDocs\Files\abc.csv.

Example:

Set CurrentYear=1992;
...
SQL SELECT * FROM table1 WHERE Year=$(CurrentYear);
Las filas con Year=1992 se seleccionarán.

Example:

Set vConcatenate = ;
For each vFile in FileList('.\*.txt')
Data:
$(vConcatenate)
LOAD * FROM [$(vFile)];
Set vConcatenate = Concatenate ;
Next vFile
En este ejemplo, todas.Los archivos txt del directorio se cargan usando el prefijo Concatenate. Esto puede ser
necesario si los archivos difieren significativamente, en cuyo caso la auto-concatenación no funciona. La
variable vConcatenate se establece inicialmente en una cadena vacía, ya que el prefijo Concatenate no se
puede usar en la primera carga. Si el directorio contiene tres archivos denominados file1.txt, file2.txt y file3.txt,
la sentencia LOAD durante las tres iteraciones se expandirá a:

LOAD * FROM[.\file1.txt];
Concatenate LOAD * FROM[.\file2.txt];
Concatenate LOAD * FROM[.\file3.txt];

Expansiones de signo dólar con parámetros


Se pueden utilizar parámetros en las expansiones de signo dólar. La variable debe contener en ese caso
parámetros formales, como $1, $2, $3 etc. Al expandir la variable, los parámetros deberían enunciarse en una
lista separada por comas.

Example:

Set MUL=’$1*$2’;

Gestión de datos - Qlik Sense, June 2019 155


4   Cargar datos con el script de carga de datos

Set X=$(MUL(3,7)); // devuelve '3*7' en X

Let X=$(MUL(3,7)); // devuelve 21 en X

Si el número de parámetros formales supera al de parámetros reales sólo se expandirán los parámetros
formales que se correspondan con parámetros reales. Si el número de parámetros reales excede al de
parámetros formales, se ignorarán los parámetros reales supérfluos.

Example:

Set MUL=’$1*$2’;
Set X=$(MUL); // devuelve '$1*$2' en X

Set X=$(MUL(10)); // devuelve '10*$2' en X

Let X=$(MUL(5,7,8)); // devuelve 35 en X

El parámetro $0 devuelve el número de parámetros realmente aprobados por una llamada.

Example:

set MUL='$1*$2 $0 par'; 


set X=$(MUL(3,7)); // devuelve '3*7 2 par' en X

Expansión de signo dólar con una expresión


Se pueden utilizar expresiones en las expansiones de signo dólar. El contenido entre paréntesis deberá
comenzar entonces por un signo igual:

$(=expression )
La expresión será evaluada y el valor se utilizará en la expansión.

Example:

$(=Year(Today())); // devuelve una cadena con el año en curso.

$(=Only(Year)-1); // devuelve el año anterior al seleccionado.

Inclusión de archivos
Las inclusiones de archivos se realizan utilizando expansiones de signo dólar. La sintaxis es la siguiente:

$(include=filename )
El texto anterior será reemplazado por el contenido del archivo especificado tras el signo igual. Esta
funcionalidad resulta de gran utilidad si desea almacenar scripts o partes de scripts en archivos de texto.

Example:

$(include=C:\Documents\MyScript.qvs);

Uso de las comillas en el script


Podemos utilizar las comillas de diversas maneras en las sentencias de script.

Gestión de datos - Qlik Sense, June 2019 156


4   Cargar datos con el script de carga de datos

En el interior de sentencias LOAD


En una sentencia LOAD se deben usar como comillas los símbolos siguientes:

Nombres de campo
Descripción Símbolo Punto de código Ejemplo

comillas dobles "" 34 "cadena"

corchetes [] 91, 93 [cadena ]

comillas oblicuas `` 96 `cadena`

Literales de cadena
Descripción Símbolo Punto de código Ejemplo

comillas simples '' 39 'cadena'

En sentencias SELECT
Para una sentencia SELECT interpretada por un driver ODBC, el uso puede variar. Por lo general, debe utilizar
las comillas dobles rectas (Alt + 0034) para los nombres de campos y tablas, y las comillas simples rectas (Alt +
0039) para los literales y evitar el uso de acentos graves. No obstante, hay algunos drivers ODBC que no solo
aceptan los acentos graves como comillas, sino que los prefieren. En tal caso, las sentencias SELECT generadas
contienen comillas con acentos graves.

Ejemplo de comillas en Microsoft Access


Microsoft Access ODBC Driver 3.4 (incluido en Microsoft Access 7.0) acepta las siguientes comillas cuando analiza
la sentencia SELECT:

Nombres de campo y Nombres de tabla:

l []
l ""
l ``

Literales de cadena:

l ''

Otras bases de datos pueden tener distintas convenciones.

Fuera de sentencias LOAD


Fuera de una sentencia LOAD, en lugares donde Qlik Sense espera una expresión, las comillas dobles
denotan una referencia de variable y no una referencia de campo. Si utilizamos las comillas dobles, la
cadena incluida en ellas se interpretará como una variable y se utilizará el valor de la variable.

Gestión de datos - Qlik Sense, June 2019 157


4   Cargar datos con el script de carga de datos

Referencias de campo fuera de contexto y referencias de tabla


Algunas funciones de script se refieren a campos que ya se han creado o que están en el resultado de una
sentencia LOAD, por ejemplo Exists() y Peek(). Estas referencias de campo se llaman referencias de
campo fuera de contexto, a diferencia de las referencias de campo fuente, que hacen referencia a campos
que están en contexto, es decir, en la tabla de entrada de la sentencia LOAD.

Las referencias de campo fuera de contexto y referencias de tabla deberían considerarse como literales y
por lo tanto necesitan comillas simples.

Diferencia entre nombres y literales


La diferencia entre los nombres y literales es clara si comparamos los siguientes ejemplos:

Example:

'Sweden' as Country
Cuando esta expresión se usa como parte de la lista de campo en una sentencia LOAD o SELECT, la cadena de
texto " Sweden" se cargará como valor de campo en el campo Qlik Sense " Country".

Example:

"land" as Country
Cuando esta expresión se utiliza como una parte de la lista de campos en una sentencia LOAD o SELECT, el
contenido del campo de la base de datos o la columna de la tabla denominada " land" se cargará como valores
de campo en el campo Qlik Sense " Country". Esto significa que land se tratará como una referencia de campo.

Diferencia entre números y literales de cadena


La diferencia entre números y literales de cadena es clara si comparamos los siguientes ejemplos:

Example:

'12/31/96'
Cuando esta cadena se utiliza como parte de una expresión, en un primer paso se interpretará como la cadena
de texto "12/31/96", que a su vez se puede interpretar como una fecha si el formato de fecha es ‘MM/DD/YY’. En
tal caso se almacenará como un valor dual con una representación tanto numérica como textual.

Example:

12/31/96
Cuando esta cadena se utiliza como parte de una expresión, se interpretará numéricamente como 12 dividida
por 31 dividida por 96.

Usar comillas en una cadena


Cuando una cadena contiene caracteres que pueden usarse como comillas, es importante indicar claramente
dónde comienza una cadena y dónde termina cuando se cita la cadena. Si la cadena no se entrecomilla
correctamente, la secuencia de script fallará o cargará los datos incorrectamente.

Hay dos métodos de citar una cadena que contiene comillas.

Gestión de datos - Qlik Sense, June 2019 158


4   Cargar datos con el script de carga de datos

Utilizar una comilla específica para citar la cadena


Elegir un símbolo de entrecomillado que no se use dentro de la cadena y utilíizarlo para citar toda la cadena.
Qlik Sense usará ese símbolo de entrecomillado específico para determinar dónde comienza y termina la
cadena.

Cualquiera de las comillas siguientes se puede utilizar para citar la cadena completa:

l Comillas dobles " "


l Corchetes [ ]
l Acentos graves ` `
l Comillas simples ' '

Example:

[Tabla '1 "2"]


Los corchetes se utilizan para citar la cadena. La cadena se carga como: Tabla '1 "2"

'string `Nombre1` "Nombre2'


Las comillas simples se utilizan para citar la cadena. La cadena se carga como: string `Nombre1` "Nombre2

Usar caracteres de escape


Los caracteres de escape son una instancia adicional de comillas que se utilizan para citar la cadena. Deben
agregarse junto a cada instancia de comillas que aparezca dentro de la cadena. Cuando todas las comillas se
usen dentro de una cadena, debe agregar caracteres de escape al lado del mismo tipo de comillas utilizado
para citar la cadena. Los caracteres de escape también se pueden usar si desea usar una comilla que ya esté en
uso en una cadena.

Solo se pueden usar como caracteres de escape los siguientes signos:

l Comillas dobles " "


l Corchetes [ ]
l Comillas simples ' '

Example:

"Miguel dijo ""Hace un día precioso""."


Si cita la cadena con las comillas dobles "", debe agregar una comilla doble adicional al lado de cada comilla
doble utilizada dentro de la cadena.

Esta cadena se carga como Miguel dijo "Hace un día precioso". Usando el carácter de escape "", el editor de
carga de datos de Qlik Sense entiende qué comillas dobles forman parte de la cadena y qué comillas indican el
final de la cadena. La comilla simple ' utilizada en la abreviatura en inglés It's no es necesario que sea de escape
porque no es el símbolo utilizado para citar la cadena.

Example:

'Michael said: "It''s a beautiful day".' (en inglés)

Gestión de datos - Qlik Sense, June 2019 159


4   Cargar datos con el script de carga de datos

Si cita esta cadena con las comillas simples "", entonces debe agregar una comilla simple adicional al lado de
cada comilla simple utilizada dentro de la cadena.

Esta cadena se carga como Michael said "It's a beautiful day". La comilla doble " utilizada en la abreviatura en
inglés para citar lo que Michael dijo no es necesario que sea de escape porque no es el símbolo utilizado para
citar la cadena.

Example:

[Michael said [It's a "beautiful day]].]


Los corchetes [] se comportan de manera diferente a las otras dos comillas. Si desea usar corchetes como
carácter de escape, debe agregar un corchete adicional al lado del corchete derecho ] solamente, y no al lado
del corchete izquierdo [.

Esta cadena se carga como Michael said [It's a "beautiful day]. Solo el corchete derecho ] es de escape. Las
comillas simples ' y las comillas dobles " utilizadas en la cadena no necesitan ser de escape, ya que no se utilizan
para citar la cadena.

Utilización de caracteres comodín en los datos


También existe la posibilidad de emplear comodines en los datos. Hay dos tipos de comodines: El símbolo
asterisco, que se interpreta como la totalidad de valores de este campo, y un símbolo opcional, que se interpreta
como todos los valores restantes de este campo.

El símbolo asterisco
El símbolo de asterisco (*) se interpreta como la totalidad de valores de este campo, es decir una lista de todos
los valores que hay en cualquier lugar de esta tabla. Si se usa en uno de los campos de sistema (USERID,
PASSWORD, NTNAME o SERIAL) en una tabla cargada en la sección de acceso del script, se interpretará como
todos los valores posibles (también los no enumerados) de este campo.

En archivos de información no se permite el uso del símbolo de asterisco. Tampoco se puede utilizar en campos
clave (es decir, campos que se emplean para unir tablas).

No hay ningún símbolo de asterisco disponible, a no ser que se especifique explícitamente. .

OtherSymbol
En muchos casos es necesario representar todos los demás valores de una tabla, es decir, todos aquellos valores
que no se han encontrado explícitamente en los datos cargados. Esto se hace con una variable especial
denominada OtherSymbol. Para definir que OtherSymbol sea tratado como "todos los demás valores", utilice
la sintaxis siguiente:

SET OTHERSYMBOL=<sym>;
antes de una sentencia LOAD o SELECT. <sym> puede ser cualquier cadena.

Si Qlik Sense encuentra el símbolo definido en una tabla interna, lo definirá como todos los valores que no han
sido previamente cargados en el campo donde lo encontró. Los valores encontrados en el campo después de
OtherSymbol se descartarán por tanto.

Para restablecer esta funcionalidad, utilice:

Gestión de datos - Qlik Sense, June 2019 160


4   Cargar datos con el script de carga de datos

SET OTHERSYMBOL=;

Example:

Table Customers
CustomerID Name

1 ABC Inc.

2 XYZ Inc.

3 ACME INC

+ Undefined

Table Orders
CustomerID Name

1 1234

3 1243

5 1248

7 1299

Inserte la sentencia siguiente en el script, delante del punto donde se carga la primera tabla superior:

SET OTHERSYMBOL=+;
Cualquier referencia a un CustomerID distinto de 1, 2 o 3, por ej. como cuando se hace clic en OrderID 1299 dará
como resultado Undefined en Name.

OtherSymbol no está diseñado para hacer outer joins entre tablas.

Manejo de valores NULL


Cuando no se pueden generar datos para un campo determinado como resultado de una consulta de base de
datos y/o una unión entre tablas, el resultado es normalmente un valor nulo o NULL.

General
La lógica de Qlik Sense trata lo siguiente como valores NULL reales:

l NULL valores devueltos de una conexión ODBC


l NULL valores creados como resultado de una concatenación forzada de tablas en el script de carga de
datos
l NULL valores creados como resultado de una unión efectuada en el script de carga de datos
l NULL valores creados como resultado de generar combinaciones de valores de campo para mostrarlos
en una tabla.

Gestión de datos - Qlik Sense, June 2019 161


4   Cargar datos con el script de carga de datos

En general, es imposible utilizar estos valores NULL para asociaciones y selecciones, excepto cuando
se está empleando la sentencia NullAsValue.

Los archivos de texto por definición no pueden contener valores NULL.

Asociar/seleccionar valores NULL desde ODBC


Es posible asociar y/o seleccionar valores NULL desde una fuente de datos ODBC. Para este fin, se ha definido
una variable de script. Se puede aplicar la sintaxis siguiente:

SET NULLDISPLAY=<sym>;
El símbolo <sym> sustituirá todos los valores NULL de la fuente de datos ODBC en el nivel más bajo de entrada
de datos. <sym> puede ser cualquier cadena.

Para restablecer esta funcionalidad a la establecida por defecto, utilice la sintaxis siguiente:

SET NULLDISPLAY=;

El uso de NULLDISPLAY solo afecta a los datos de una fuente de datos ODBC.

Si desea que la lógica de Qlik Sense interprete los valores NULL devueltos desde una conexión ODBC como una
cadena vacía, agregue lo siguiente a su script antes de cualquier sentencia SELECT:

SET NULLDISPLAY=";

Aquí " son dos signos de entrecomillado simple, o comillas simples, sin nada entre ellas.

Crear valores NULL desde archivos de texto


Es posible definir un símbolo, que cuando aparece en un archivo de texto o una cláusula inline se interpretará
como un valor NULL real. Use la siguiente sentencia:

SET NULLINTERPRET=<sym>;
El símbolo <sym> se debe interpretar como NULL. <sym> puede ser cualquier cadena.

Para restablecer esta funcionalidad a la establecida por defecto, use:

SET NULLINTERPRET=;

El uso de NULLINTERPRET solo afecta a datos de archivos de texto y cláusulas inline.

Propagación de valores NULL en expresiones


Los valores NULL se propagarán a través de una expresión de acuerdo con algunas reglas lógicas y bastante
razonables.

Gestión de datos - Qlik Sense, June 2019 162


4   Cargar datos con el script de carga de datos

Funciones
La regla general es que las funciones devuelven NULL cuando los parámetros caen fuera del rango para el que
se ha definido la función.

Ejemplos
Expresión Resultado

asin(2) devuelve NULL

log(-5) devuelve NULL

round(A,0) devuelve NULL

Como resultado de lo anterior, las funciones generalmente devuelven NULL cuando alguno de los parámetros
necesarios para la evaluación es NULL.

Ejemplos
Expresión Resultado

sin(NULL) devuelve NULL

chr(NULL) devuelve NULL

if(NULL, A, B) devuelve B

if(True, NULL, A) devuelve NULL

if(True, A, NULL) devuelve A

La excepción a la segunda regla es que las funciones lógicas comprueban el tipo.

Ejemplos
Expresión Resultado

isnull(NULL) devuelve True (-1)

isnum(NULL) devuelve False (0)

Operadores aritméticos y de cadena


Si NULL se encuentra a cualquier lado de estos operadores, devuelve NULL.

Ejemplos
Expresión Resultado

A + NULL devuelve NULL

A - NULL devuelve NULL

A / NULL devuelve NULL

A * NULL devuelve NULL

Gestión de datos - Qlik Sense, June 2019 163


4   Cargar datos con el script de carga de datos

Expresión Resultado

NULL / A devuelve NULL

0 / NULL devuelve NULL

0 * NULL devuelve NULL

A & NULL devuelve A

Operadores relacionales
Si NULL se encuentra a cualquier lado de los operadores relacionales se aplican reglas especiales.

Ejemplos
Expresión Resultado

NULL (cualquier operador relacional) NULL devuelve NULL

A <> NULL devuelve True (-1)

A < NULL devuelve False (0)

A <= NULL devuelve False (0)

A = NULL devuelve False (0)

A >= NULL devuelve False (0)

A > NULL devuelve False (0)

4.4 Directrices para datos y campos


Existen determinadas convenciones y limitaciones que debe conocer para trabajar con Qlik Sense. Por ejemplo:
el límite superior para las tablas de datos y los campos, así como el volumen máximo de datos cargados en Qlik
Sense.

Directrices para la cantidad máxima de datos cargados


La cantidad de datos que se pueden cargar en Qlik Sense viene limitada en primer lugar por la cantidad de
memoria primaria que posee el ordenador.

Límites máximos de campos y tablas de datos


Tenga cuidado cuando cree apps muy extensas, que una app Qlik Sense no puede tener más de 2.147.483.648
valores distintos en un campo.

El número de campos y tablas de datos, así como el número de celdas y filas de tabla que se pueden cargar
viene delimitado exclusivamente por la cantidad de RAM.

Límite recomendado para secciones de load script de carga


El número máximo recomendado de caracteres que se pueden utilizar por sección de script de carga es de
50.000 caracteres.

Gestión de datos - Qlik Sense, June 2019 164


4   Cargar datos con el script de carga de datos

Convenciones para formatos numéricos y de tiempo


En muchas funciones de interpretación y formato se puede configurar el formato de números y fechas
empleando un código de formato. Este tema describe las convenciones utilizadas para dar formato a un
número, fecha, hora o fecha-hora. Esto es aplicable tanto a las funciones de script como de gráfico.

Formatos numéricos
Para indicar una cantidad específica de dígitos, utilice el símbolo "0" para cada dígito.

Para indicar un posible dígito a la izquierda del punto decimal, use el símbolo "#".

Para marcar la posición del separador de miles o separador decimal, utilice el correspondiente separador de
miles o el separador decimal.

El código de formato se utiliza para definir las posiciones de los separadores. No es posible configurar el
separador en el código de formato. Utilice las variables DecimalSep y ThousandSep para esto en el script.

Se puede usar el separador de miles para agrupar dígitos por cualquier número de posiciones, por ejemplo, se
podría usar una cadena de formato de "0000-0000-0000" (separador de miles = "-") para mostrar un número de
parte de doce dígitos, como "0012-4567-8912".

Examples:

Ejemplo de formatos numéricos


Formato
Descripción
numérico

# ##0 describe el número como un entero con un separador de miles. En este ejemplo " " se
utiliza como separador de miles.

###0 describe el número como un entero sin separador de miles.

0000 describe el número como un entero con, al menos, cuatro dígitos. Por ejemplo, el número
123 se mostrará como 0123.

0.000 describe el número con tres decimales. En este ejemplo "." se utiliza como separador
decimal.

Formatos especiales de número


Qlik Sense puede interpretar y dar formato a los números de cualquier base de numeración entre el 2 y el 36,
incluyendo binario, octal y hexadecimal. También puede manejar formatos de números romanos.
Formatos especiales de número
Formato Descripción

Formato Para indicar el formato binario, el código de formato debe comenzar por (bin) o (BIN).
binario

Formato octal Para indicar el formato octal, el código de formato debe comenzar por (oct) o (OCT).

Gestión de datos - Qlik Sense, June 2019 165


4   Cargar datos con el script de carga de datos

Formato Descripción

Formato Para indicar el formato hexadecimal, el código de formato debe comenzar por (hex) o
hexadecimal (HEX). Si se usa la versión en mayúsculas A-F se usará para dar formato (por ejemplo 14FA).
La versión que no va en mayúsculas dará como resultado el formato con a-f (por ejemplo
14fa). La interpretación funcionará para ambas variantes, sin distinguir entre mayúsculas y
minúsculas en el código de formato.

Formato El uso de (dec) o (DEC) para indicar el formato decimal se permite pero no es necesario.
decimal

Formato de Para indicar un formato en cualquier base entre 2 y 36, el código de formato debe
base comenzar por (rxx) o (Rxx), donde xx es el número de dos dígitos que denota la base que se
numérica utilizará. Si se utiliza el texto R en mayúscula, las letras en bases por encima de 10 se
personalizado escribirán con mayúscula cuando Qlik Sense esté dando formato (por ejemplo, 14FA). La r
que no va en mayúsculas dará como resultado un formato con letras no mayúsculas (por
ejemplo, 14fa). La interpretación funcionará para ambas variantes, sin distinguir entre
mayúsculas y minúsculas en el código de formato. Observe que (r02) es el equivalente de
(bin), (R16) es el equivalente de (HEX), etc.

Formato Para indicar números romanos el código de formato debe comenzar por (rom) o (ROM). Si
romano se usa la versión en mayúscula las letras mayúsculas se usarán para dar formato (por
ejemplo MMXVI). La versión que no va en mayúsculas dará como resultado el formato con
letras en minúscula mmxvi. La interpretación funcionará para ambas variantes, sin
distinguir entre mayúsculas y minúsculas en el código de formato. Los números romanos
reciben por lo general un signo menos para indicar los números negativos y 0 representa
cero. Los decimales se ignorarán en el caso del formateado de números romanos.

Examples:

Ejemplos de formatos numéricos especiales


Ejemplo Resultado

num(199, '(bin)') devuelve 11000111

num(199, '(oct)') devuelve 307

num(199, '(hex)') devuelve c7

num(199, '(HEX)' ) devuelve C7

num(199, '(r02)' ) devuelve 11000111

num(199, '(r16)') devuelve c7

num(199, '(R16)' ) devuelve C7

num(199, '(R36)') devuelve 5J

num(199, '(rom)') devuelve cxcix

num(199, '(ROM)' ) devuelve CXCIX

Gestión de datos - Qlik Sense, June 2019 166


4   Cargar datos con el script de carga de datos

Fechas
Podemos utilizar los siguientes símbolos para dar formato a una fecha. Se podrá emplear cualquier separador.

Símbolos para dar formato a una fecha


Símbolos Descripción

D Para describir el día, use el símbolo "D" para cada dígito.

M Para describir el número de mes, use el símbolo "M".

Use "M" o "MM" para uno o dos dígitos.

"MMM" denota el nombre corto del mes en letras según lo define el sistema operativo o la
variable del sistema de anulación MonthNames en el script.

"MMMM" denota el nombre largo del mes en letras según lo define el sistema operativo o la
variable del sistema de anulación LongMonthNames en el script.

Y Para describir el año, use el símbolo "Y" para cada dígito.

W Para describir el día de la semana, use el símbolo "W".

"W" devolverá el número de día (por ejemplo, 0 para el lunes) como un solo dígito.

"WW" devolverá el número con dos dígitos (por ejemplo, 02 para el miércoles).

"WWW" mostrará la versión corta del nombre del día de la semana (por ejemplo, Lun) según lo
definido por el sistema operativo o por la variable de anulación del sistema DayNames en el
script.

"WWWW" mostrará la versión larga del nombre del día de la semana (por ejemplo, Lunes) según
lo definido por el sistema operativo o por la variable de anulación del sistema LongDayNames
en el script.

Examples: (con el 31 de marzo de 2013 como fecha a modo de ejemplo)

Ejemplos de formatos de fecha


Ejemplo Resultado

YY-MM-DD describe la fecha como 13-03-31.

YYYY-MM-DD describe la fecha como 2013-03-31.

YYYY-MMM-DD describe la fecha como 2013-Mar-31.

DD MMMM YYYY describe la fecha como 31 de marzo de 2013.

M/D/YY describe la fecha como 3/31/13.

W YY-MM-DD describe la fecha como 6 13-03-31.

WWW YY-MM-DD describe la fecha como Sáb 13-03-31.

WWWW YY-MM-DD describe la fecha como Sábado 13-03-31.

Gestión de datos - Qlik Sense, June 2019 167


4   Cargar datos con el script de carga de datos

Horas
Podemos utilizar los siguientes símbolos para dar formato a una hora. Se podrá emplear cualquier separador.

Símbolos para dar formato a una hora


Símbolos Descripción

h Para describir las horas, use el símbolo "h" para cada dígito.

m Para describir los minutos, use el símbolo "m" para cada dígito.

s Para describir los segundos, use el símbolo "s" para cada dígito.

f Para describir las fracciones de un segundo, use el símbolo "f" para cada dígito.

tt Para describir la hora en formato AM/PM, use el símbolo "tt" después de la hora.

Examples: (con 18.30 como ejemplo de hora):

Ejemplos de formatos de hora


Ejemplo Resultado

hh:mm describe la hora como 18:30.

hh.mm.ss.ff describe la hora como 18.30.00.00

hh:mm:tt describe la hora como 18.30.00.00.

Fecha/Hora
Se emplea la misma notación que la expresada anteriormente para fechas y horas.

Examples: (con el 31 de marzo de 2013 a las 18.30 como fecha y hora a modo de ejemplo):

Ejemplos de formatos de fecha-hora


Ejemplo Resultado

YY-MM-DD hh:mm describe la fecha-hora como 13-03-31 18:30.

M/D/Y hh.mm.ss.ffff describe la fecha-hora como 3/31/13 18.30.00.0000.

4.5 Trabajar con archivos QVD


Un archivo QVD (QlikView Data) es un archivo que contiene una tabla de datos exportados desde Qlik Sense.
QVD es un formato nativo de Qlik y solo pueden leerlo y escribirlo Qlik Sense o QlikView. El formato de archivo
está optimizado para mejorar la velocidad de lectura de datos desde un script, siendo al mismo tiempo muy
compacto. Leer datos desde un archivo QVD es por lo general 10-100 veces más rápido que leer de otras fuentes
de datos.

Los archivos QVD se puede leer en dos modos: estándar (rápido) y optimizado (más rápido). El modo que se
utilice viene determinado de forma automática por el motor de script.

Gestión de datos - Qlik Sense, June 2019 168


4   Cargar datos con el script de carga de datos

Hay algunas limitaciones con respecto a las cargas optimizadas. Es posible cambiar el nombre de los campos,
pero cualquiera de las operaciones aquí mencionadas deshabilitará la carga optimizada y dará como resultado
una carga estándar.

l Cualquier transformación en los campos que se cargan.


l Usar una cláusula where que ocasione que Qlik Sense descomprima los registros.
l Usar Map en un campo que se carga.

Finalidad de los archivos QVD


Los archivos QVD se pueden usar con muchos fines y más de uno puede aplicarse en cualquier situación dada.
Podemos identificar claramente al menos cuatro usos fundamentales.

l Incremento de la velocidad de carga


Al almacenar en búfer los bloques de datos de entrada que no cambian o que cambian lentamente en
los archivos QVD, la ejecución de script se vuelve considerablemente más rápida para los grandes
conjuntos de datos.

l Reducción de la carga en los servidores de las bases de datos


Mediante el envío a buffers de las partes que no cambian, o cambian muy lentamente, de los datos de
entrada de archivos QVD, podemos reducir enormemente la cantidad de datos obtenidos de fuentes de
datos externas. Esto alivia la carga de las bases de datos externas y reduce el tráfico de la red. Además,
cuando varios scripts comparten los mismos datos, solo es necesario cargarlo una vez desde la base de
datos de origen en un archivo QVD. Otras apps pueden hacer uso de los mismos datos a través de este
archivo QVD.

l Consolidar datos de múltiples apps


Con la sentencia de script binary, los datos se pueden cargar desde una sola app a otra, pero con los
archivos QVD, un script puede combinar datos de cualquier cantidad de apps. Esto permite a las apps
consolidar datos similares de distintas unidades de negocio, por ejemplo.

l Incremental
En muchos casos habituales, la funcionalidad del QVD puede usarse para la carga incremental,
cargando solo los nuevos registros de una base de datos en aumento.

Crear archivos QVD


Un archivo QVD se puede crear de dos maneras:

l Mediante la creación explícita y su nombrado mediante el comando store en el script. Indique


simplemente en el script que desea exportar una tabla anteriormente leída, o parte de ella, a un
nombre de archivo explícito, en una ubicación de su elección.
l Mediante creación y mantenimiento automáticos desde el script. Cuando se coloca el prefijo
buffer delante de una sentencia LOAD o SELECT con , Qlik Sense creará automáticamente un
archivo QVD, que, bajo ciertas condiciones, se puede utilizar en lugar de la fuente de datos
original al volver a cargar los datos.

No hay diferencia entre los archivos QVD resultantes con respecto a la velocidad de lectura.

Gestión de datos - Qlik Sense, June 2019 169


4   Cargar datos con el script de carga de datos

Leer datos desde archivos QVD


Un archivo QVD se puede leer o está accesible mediante los siguientes métodos:

l Cargar un archivo QVD como una fuente de datos explícita. Los archivos QVD se pueden
referenciar mediante una sentencia LOAD en el script, igual que cualquier otro tipo de archivos
de texto (csv, fix, dif, biff, etc.).
Por ejemplo (Windows):
l LOAD * from xyz.qvd (qvd);
l LOAD Name, RegNo from xyz.qvd (qvd);
l LOAD Name as a, RegNo as b from xyz.qvd (qvd);

Por ejemplo (Kubernetes):


l LOAD * from [lib://MyDataFiles/xyz.qvd];
l LOAD Name, RegNo from [lib://MyDataFiles/xyz.qvd];
l LOAD Name as a, RegNo as b from [lib://MyDataFiles/xyz.qvd];

l Carga automática de archivos QVD almacenados en el búfer. Cuando utiliza el prefijo buffer en
sentencias LOAD o SELECT no son necesarias sentencias explícitas para la lectura. Qlik Sense
determinará en qué medida utilizará los datos del archivo QVD en lugar de adquirir los datos
utilizando la sentencia LOAD o SELECT original.
l Acceder a archivos QVD desde el script. Se pueden usar varias funciones de script (todas ellas
comenzando por qvd) para recuperar información diversa sobre los datos encontrados en la
cabecera XML de un archivo QVD.

Formato QVD
Un archivo QVD contiene exactamente una tabla de datos y consta de tres partes:

l Cabecera.

Si el archivo QVD se generó con QlikView la cabecera es un encabezado XML bien


formado (en el juego de caracteres UTF-8) que describe los campos de la tabla, el
diseño de la información posterior y otros metadatos.

l Tablas de símbolos en un formato de bytes.


l Datos reales de la tabla en formato de bits.

4.6 Gestionar la seguridad con sección de acceso


Puede utilizar la sección de acceso en el script de carga de datos para controlar la seguridad. De esta forma,
puede incluir los datos de diferentes usuarios o grupos de usuarios en un solo archivo. Qlik Sense utiliza la
información de la sección de acceso para los procesos de autenticación y autorización, y reduce
dinámicamente los datos para que los usuarios sólo puedan ver sus propios datos.

Kubernetes no admite grupos de usuarios.

Gestión de datos - Qlik Sense, June 2019 170


4   Cargar datos con el script de carga de datos

La seguridad se incorpora en el propio archivo, lo que significa que los archivos descargados siempre estarán
protegidos, hasta cierto punto. No obstante, si se requiere una seguridad elevada, se debe evitar la descarga de
archivos y su uso sin conexión; asimismo, los archivos solamente los debe publicar el servidor Qlik Sense. Como
todos los datos se almacenan en un solo archivo, el tamaño de dicho archivo puede llegar a ser considerable.

Para evitar exponer datos restringidos, elimine todos los archivos adjuntos con la configuración de
sección de acceso antes de publicar la app.

Los archivos adjuntos se incluyen cuando la app se publica. Si la app publicada se copia, los
archivos adjuntos se incluyen en la copia. Sin embargo, si se han aplicado restricciones de sección
de acceso a los archivos de datos adjuntos, la configuración de la sección de acceso no se conserva
al copiarse los archivos, por lo que los usuarios de la app copiada podrán ver todos los datos en los
archivos adjuntos.

Una captura de imagen muestra los datos conforme a los derechos de acceso que posea el usuario
que toma la captura y esta captura puede después compartirse en una historia. No obstante,
cuando los usuarios retornan a una visualización desde una historia para ver los datos en vivo en la
app, se ven restringidos por sus propios derechos de acceso.

No debe asignar colores a valores de dimensión maestra si utiliza sección de acceso o trabaja con
datos confidenciales, porque los valores pueden quedar expuestos.

Secciones en el script
El control de acceso se gestiona mediante una o varias tablas de seguridad cargadas de la misma manera que
los datos se cargan normalmente en Qlik Sense. Esto permite almacenar las tablas en una base de datos
normal. Las sentencias de script que gestionan las tablas de seguridad se proporcionan en la sección de acceso,
lo que en el script se inicia mediante la sentencia Section Access.

Si se define una sección de acceso en el script, la parte del script que carga los datos de la app deberá colocarse
en una sección distinta, iniciada por la sentencia Section Application .

Example:

Section Access;
LOAD * inline [
ACCESS, USERID
USER, User_ID
];
Section Application;
LOAD... ... from... ...

Gestión de datos - Qlik Sense, June 2019 171


4   Cargar datos con el script de carga de datos

Campos de sistema en la sección de acceso


Los niveles de acceso se asignan a los usuarios en una o varias tablas cargadas dentro de la sección de acceso.
Estas tablas pueden contener diferentes campos de sistema específicos de usuario, generalmente USERID, y el
campo que define el nivel de acceso, ACCESS. Todos los campos de sistema de la sección de acceso se
emplearán para autenticación y autorización. A continuación se describen todos los campos de sistema de la
sección de acceso.

ACCESS
Define el tipo de acceso que debe tener un usuario específico.

El acceso a las apps de Qlik Sense puede autorizarse a determinados usuarios o grupos de usuarios específicos.
En la tabla de seguridad, se puede asignar a los usuarios a los niveles de acceso ADMIN o USER. Si no se asigna
un nivel de acceso válido, el usuario no podrá abrir la app.

Una persona con privilegios de ADMIN tiene acceso a todos los datos de la app. Una persona con privilegios de
USER solo puede acceder a los datos tal como se define en la tabla de seguridad.

Si se utiliza sección de acceso en un escenario de generación de apps (ODAG) bajo demanda en la app de
plantilla, el usuario INTERNAL\SA_API debe incluirse como ADMIN en la tabla de la sección de acceso. Por
ejemplo:

Section Access;
LOAD * inline [
ACCESS, USERID
ADMIN, INTERNAL\SA_API
];

USERID
Contiene una cadena que corresponde a un nombre de usuario de Qlik Sense. Qlik Sense recibirá la información
de inicio de sesión del proxy y la comparará con el valor introducido en este campo.

GROUP
Contiene una cadena que corresponde a un grupo de Qlik Sense. Qlik Sense resolverá el usuario proporcionado
por el proxy con este grupo.

Cuando utilice grupos para reducir datos y desee Qlik Management Console, todavía se requiere el
usuario de la cuenta INTERNAL\SA_SCHEDULER.

OMIT
Contiene el nombre del campo que se debe omitir para este usuario específico. Se puede hacer uso de
comodines y el campo puede dejarse vacío. Una forma sencilla de realizar esto consiste en utilizar un
subcampo.

Gestión de datos - Qlik Sense, June 2019 172


4   Cargar datos con el script de carga de datos

Le recomendamos que no aplique OMIT en campos clave. Los campos clave que se omiten están
visibles en el visor del modelo de datos, pero el contenido no está disponible, lo que podría ser
confuso para el usuario. Además, aplicar OMIT en campos que se utilizan en una visualización
puede dar como resultado una visualización incompleta para usuarios que no tengan acceso a los
campos omitidos.

Qlik Sense comparará el usuario proporcionado por el proxy con UserID y resolverá el usuario con los grupos de
la tabla. Si el usuario pertenece a un grupo con permiso de acceso, o si el usuario coincide, podrá acceder a la
app.

Si ha quedado bloqueado y no logra acceder a una app mediante la sección de acceso, puede abrir
la app sin sus datos y editar la sección de acceso en el script de carga de datos. Esto requiere acceso
a edición y carga del script de carga de datos.

Como en la sección de acceso también se utiliza la misma lógica interna característica de Qlik Sense, los
campos de seguridad se pueden colocar en diferentes tablas. Todos los campos enumerados en sentencias
LOAD o SELECT en la sección de accesso deben escribirse en MAYÚSCULAS. Convierta cualquier nombre de
campo de la base de datos que contenga letras minúsculas a mayúsculas utilizando la función Upper antes de
que la sentencia LOAD o SELECT lea el campo.

Un carácter comodín, por ejemplo el asterisco (*), se interpreta como todos los valores (incluidos en la lista) de
este campo, es decir, un valor que aparece en otros lugares de la tabla. Si se usa en uno de los campos de
sistema (USERID, GROUP) de una tabla cargada en la sección de acceso del script, se interpretará como todos
los valores posibles (también los no enumerados) de este campo.

Cuando se cargan datos desde un archivo QVD, el uso de la función superior ralentizará la
velocidad de carga.

Si ha habilitado la sección de acceso, no podrá utilizar los nombres de campos de sistema de la


sección de acceso indicados aquí como nombres de campos en el modelo de datos.

Example:

En este ejemplo, solo los usuarios del grupo financiero pueden abrir el documento.

Acceso al documento
Acceso Grupo

USUARIO Finanzas

Gestión de datos - Qlik Sense, June 2019 173


4   Cargar datos con el script de carga de datos

Reducción dinámica de datos


Qlik Sense admite la funcionalidad de reducción dinámica de datos, mediante la cual algunos de los datos de
una app pueden ocultarse a la vista de un usuario conforme al inicio de sesión efectuado en la sección de
acceso:

l Los campos (columnas) se pueden ocultar utilizando el campo de sistema OMIT.


l Los registros (filas) pueden ocultarse enlazando los datos de la sección de acceso con los datos reales: La
selección de valores que se habrán de mostrar o excluir se controla teniendo uno o más campos con
nombres comunes en la sección de acceso y en la sección de la aplicación. Una vez que el usuario ha
iniciado sesión, Qlik Sense tratará de contrastar las selecciones de campos de la sección de acceso con
los campos de la sección de aplicación que tengan exactamente los mismos nombres de campo (los
nombres de los campos deben estar en MAYÚSCULAS). Una vez que el usuario ha iniciado la sesión, Qlik
Sense ocultará de forma permanente todos los datos excluidos por estas selecciones de la vista del
usuario.

Todos los nombres de campo empleados en la transferencia descrita anteriormente y todos los
valores de campo de estos campos deberán ir en mayúsculas, ya que todos los nombres de campo
y los valores de campo se convierten por defecto en mayúsculas en la sección de acceso.

Si desea habilitar la carga de script en una tarea Qlik Management Console, se requiere el usuario
de la cuenta INTERNAL\SA_SCHEDULER con acceso a ADMIN.

Example: Reducción de datos basada en ID de usuario

Section Access;
LOAD * inline [
ACCESS, USERID, REDUCTION, OMIT
USER, AD_DOMAIN\ADMIN, *,
USER, AD_DOMAIN\A, 1,
USER, AD_DOMAIN\B, 2, NUM
USER, AD_DOMAIN\C, 3, ALPHA
ADMIN, INTERNAL\SA_SCHEDULER, *,
];
section application;
T1:
LOAD *,
NUM AS REDUCTION;
LOAD
Chr( RecNo()+ord('A')-1) AS ALPHA,
RecNo() AS NUM
AUTOGENERATE 3;
El campo REDUCTION (mayúsculas) existe ahora tanto en la sección de acceso como en la sección de aplicación
(todos los valores de campos van también en mayúsculas). Por lo general, serían dos campos totalmente
diferentes y separados; pero al utilizar la sección de acceso, estos campos se vinculan y se reduce el número de
registros que se muestran al usuario.

Gestión de datos - Qlik Sense, June 2019 174


4   Cargar datos con el script de carga de datos

El campo OMIT, en la sección de acceso, define los campos que deberían ocultarse del usuario.

El resultado será:

l El usuario ADMIN puede ver todos los campos y solo aquellos registros que otros usuarios pueden ver en
este ejemplo cuando REDUCTION sea 1, 2 o 3.
l El usuario A puede ver todos los campos, pero solo aquellos registros asociados a REDUCTION=1.
l El usuario B puede ver todos los campos excepto NUM y solo aquellos registros asociados a
REDUCTION=2.
l El usuario C puede ver todos los campos excepto ALPHA y solo aquellos registros asociados a
REDUCTION=3.

Example: Reducción de datos basada en grupos de usuarios

Section Access;
LOAD * inline [
ACCESS, USERID, GROUP, REDUCTION, OMIT
USER, *, ADMIN, *,
USER, *, A, 1,
USER, *, B, 2, NUM
USER, *, C, 3, ALPHA
USER, *, GROUP1, 3,
ADMIN, INTERNAL\SA_SCHEDULER, *, *,
];
section application;
T1:
LOAD *,
NUM AS REDUCTION;
LOAD
Chr( RecNo()+ord('A')-1) AS ALPHA,
RecNo() AS NUM
AUTOGENERATE 3;
El resultado será:

l Los usuarios que pertenecen al grupo ADMIN pueden ver todos los datos y todos los campos.
l Los usuarios que pertenecen al grupo A pueden ver los datos asociados a REDUCTION=1 en todos los
campos.
l Los usuarios que pertenecen al grupo B pueden ver los datos asociados a REDUCTION=2, pero no en el
campo NUM
l Los usuarios que pertenecen al grupo C pueden ver los datos asociados a REDUCTION=3, pero no en el
campo ALPHA
l Los usuarios que pertenecen al grupo GROUP1 pueden ver los datos asociados a REDUCTION=3 en todos
los campos
l El usuario INTERNAL\SA_SCHEDULER no pertenece a ningún grupo, pero se le permite ver todos los datos
de todos los campos.

Gestión de datos - Qlik Sense, June 2019 175


4   Cargar datos con el script de carga de datos

El carácter comodín *, en esta fila se refiere solo a todos los valores dentro de la tabla de la
sección de acceso. Si hay valores en la aplicación de sección que no están disponibles en el
campo REDUCTION en la sección de acceso, se reducirán.

Restricciones de acceso heredadas

Esta funcionalidad no está disponible en Kubernetes.

Una carga binaria hará que la nueva app de Qlik Sense herede las restricciones de acceso.

4.7 Configurar conexiones analíticas en Qlik Sense Desktop


Con las conexiones analíticas puede integrar el análisis externo con sus descubrimientos de negocio. Una
conexión analítica amplía las expresiones que puede utilizar en los scripts y gráficos de carga llamando a un
motor de cálculo externo (cuando hace esto, el motor de cálculo actúa como una extensión del lado del servidor
(SSE)). Por ejemplo, podría crear una conexión analítica con R y usar expresiones estadísticas cuando cargue
los datos.

Para Qlik Sense Desktop, la configuración se debe hacer en el archivo Settings.ini.

Haga lo siguiente:

1. Abra el archivo Settings.ini.


Para Qlik Sense Desktop está ubicado en C:/Users/<User ID>/Documents/Qlik/Sense/ o en
C:/Users/AppData/Local/Programs/Qlik/Sense/Engine.
Para Qlik Sense se encuentra en: C:/ProgramData/Qlik/Sense/Engine/ .
2. Agregue la siguiente configuración (observe la línea vacía al final):
[Settings 7]
SSEPlugin=<PluginConfig>[;<PluginConfig>...]

Donde <PluginConfig> es una lista de elementos de configuración separados por comas que contiene lo
siguiente:

<EngineName>,<Address>[,<PathToCertFile>,<RequestTimeout>,<ReconnectTimeout>]

Después de agregar nuevas conexiones o cambiar las conexiones existentes, se requiere un reinicio
de Qlik Sense Desktop para que los cambios surtan efecto.

Tenga en cuenta que el servidor del complemento plugin de la extensión del servidor (SSE) debe
estar ejecutándose antes de iniciar Qlik Sense, de lo contrario no se establecerá la conexión.

Gestión de datos - Qlik Sense, June 2019 176


4   Cargar datos con el script de carga de datos

Qlik repositorios SSE de código abierto


Los dos repositorios siguientes SSE de Qlik son de código abierto:

l https://github.com/qlik-oss/server-side-extension
Contiene el protocolo SSE, documentación general y ejemplos escritos en Python y C ++.

l https://github.com/qlik-oss/sse-r-plugin
Contiene un plugin R escrito en C#, solo el código fuente. Debe crear el complemento plugin antes de
poder usarlo.

Descripción de los elementos


<EngineName>: Asignación/alias del plugin que se usará desde dentro de las expresiones en la app usando las
funciones del complemento plugin, por ejemplo, SSEPython para un plugin Python.

<Address>: lista separada por dos puntos con dos elementos y

l <Host>: Nombre DNS (o dirección IP) del complemento plugin.

l <Port>: Puerto en el que escucha el complemento plugin, normalmente el 50051.

<PathToCertFile>: Ruta del sistema de archivos a la carpeta que contiene los certificados del cliente necesarios
para la comunicación segura con el complemento plugin. Opcional. Si se omite, se invocará una comunicación
insegura. Esta ruta de acceso solo apunta a la carpeta donde se encuentran los certificados. Asegúrese de que
realmente se copian a esa carpeta. Los nombres de los tres archivos de certificado deben ser los siguientes:
root_cert.pem, sse_client_cert.pem, sse_client_key.pem. Únicamente se permite autenticación mutua
(autenticación cliente y servidor).

<RequestTimeout>: Entero (segundos). Opcional. El valor predeterminado es 0 (infinito). Tiempo de espera para
la duración del mensaje.

<ReconnectTimeout>: Entero (segundos). Opcional. El valor predeterminado es 20 (segundos). Tiempo antes de


que el cliente intente volver a conectarse al complemento plugin después de que se haya perdido la conexión
con el plugin.

Examples:

l Ejemplo donde se define un servidor de complementos plugin SSE:


SSEPlugin=SSEPython,localhost:50051

l Ejemplo donde se definen dos servidores de complementos plugin SSE:


SSEPlugin=SSEPython,localhost:50051;R,localhost:50053

l Ejemplo donde se define un servidor de complementos plugin SSE sin ruta de certificado, pero con
tiempos de espera configurados: SSEPlugin=SSEPython,localhost:50051,,0,20

Gestión de datos - Qlik Sense, June 2019 177


5   Gestionar grandes fuentes de datos big data con apps a demanda

5 Gestionar grandes fuentes de datos big data


con apps a demanda
Las apps a demanda le permiten cargar y analizar grandes fuentes de datos «big data» en Qlik Sense Enterprise.
Tratar de analizar una gran extensión de datos toda de una vez es altamente ineficiente. Pero para hacer unas
visualizaciones que de verdad sean útiles, debemos poner todos los datos al descubierto. Las apps a demanda
de Qlik Sense ofrecen a los usuarios unas vistas agregadas de los grandes conjuntos de datos y les permiten
identificar y cargar subconjuntos relevantes de datos para un análisis detallado.

Las apps a demanda amplían y mejoran los posibles casos de uso de las técnicas de descubrimiento de datos,
permitiendo a los usuarios de negocio efectuar análisis asociativos en fuentes de datos muy extensas. Permiten
a los usuarios seleccionar primero los datos de los que deseen obtener más conocimientos y generar después de
forma interactiva una app a demanda con la que analizar los datos con todas las capacidades completas en
memoria de Qlik.

5.1 Componentes de una app a demanda


Qlik Sense gestiona la carga de fuentes de datos extensas mediante unas apps de selección que proporcionan
unas vistas agregadas de los datos y también permiten que el usuario amplíe y analice los datos a nivel de
detalle. En cada app de selección se incluyen enlaces de navegación de app a demanda a una o más apps de
plantilla, las cuales se utilizan como base para crear apps a demanda. Las propiedades de los enlaces de
navegación y las apps de plantilla le permiten controlar totalmente la forma y el volumen de los datos cargados
en las apps a demanda.

Las apps se pueden generar una y otra vez desde la app de plantilla de forma repetida para permitir un buen
seguimiento de conjuntos de datos que cambian con frecuencia. Mientras los datos se filtran conforme a las
selecciones realizadas en la app de selección, el contenido de la app a demanda se carga dinámicamente desde
el origen de datos subyacente. La misma app a demanda puede generarse múltiples veces para hacer nuevos
análisis de los datos a medida que estos cambian.

La generación de apps a demanda es controlada por el servicio de apps a demanda. El servicio está
deshabilitado de forma predeterminada y debe habilitarse antes de poder vincular las apps de
plantilla y las apps a demanda. El servicio de apps a demanda se administra en la consola Qlik
Management Console.

Relaciones entre los componentes de una app a demanda.

Gestión de datos - Qlik Sense, June 2019 178


5   Gestionar grandes fuentes de datos big data con apps a demanda

5.2 Construir apps a demanda


Debido a que las apps de selección a demanda y las apps de plantilla requieren un script de carga especial,
normalmente las crean usuarios con experiencia en la redacción de scripts de carga de Qlik Sense. Las apps de
selección a demanda, por ejemplo, deben cargar datos con un nivel modesto de granularidad de dimensiones.
Las apps de plantilla a demanda contienen scripts de carga con expresiones de enlace a datos utilizadas para
formular las consultas realizadas en las fuentes de datos.

Una app de selección se puede vincular a varias apps de plantilla y una única app de plantilla puede vincularse
mediante varias apps de selección. Pero las expresiones de enlace de datos de la app de plantilla deben
corresponderse con campos de las apps de selección que estén vinculados con la misma. Por esa razón, las apps
de selección y de plantilla tienden a crearse de forma conjunta y, a menudo, por el mismo y experimentado
redactor de script.

Hay ejemplos de apps de selección a demanda y apps de plantilla incluidos en la instalación de Qlik
Sense Enterprise en ProgramData\Qlik\Examples\OnDemandApp\sample. Esta funcionalidad no
está disponible en Kubernetes.

Crear enlaces de navegación también requiere una buena comprensión de los campos de la app de selección
que tienen sus correspondientes enlaces en la app de plantilla. Esto se debe a que cada enlace de navegación
requiere una expresión que calcule el número total de registros de detalle. Ese total representa los registros
agregados accesibles a través del estado de selección en la app de selección. Para crear esa expresión, es
necesario que el usuario sepa cómo calcular el recuento total de registros de la app de plantilla usando los
campos disponibles en la app de selección.

Gestión de datos - Qlik Sense, June 2019 179


5   Gestionar grandes fuentes de datos big data con apps a demanda

El uso de apps de selección para generar aplicaciones a demanda no requiere que el usuario entienda el script
de carga. Una vez que se ha creado un enlace de navegación de app a demanda, un usuario puede arrastrar
ese enlace de navegación hacia la barra de navegación de app de la App de selección para crear un punto de
navegación de la app. Las apps a demanda se generan entonces en el punto de navegación de la app.

Los puntos de navegación están disponibles para la generación de apps a demanda cuando el cálculo de filas
máximo de la expresión en el enlace de navegación se encuentra dentro del rango requerido. En ese punto, el
usuario puede generar una app a demanda. El usuario también puede hacer otro conjunto de selecciones y
generar apps adicionales basadas en esas selecciones diferentes.

Los enlaces de navegación tienen un límite en el número de apps a demanda que se pueden generar desde el
enlace. Cuando se ha generado el número máximo de apps, el usuario que está generando apps desde el punto
de navegación debe eliminar una de las apps existentes antes de generar una nueva app a demanda. El número
máximo de apps generadas se aplica al enlace de navegación de la app a demanda. Si se crea un punto de
navegación de app a demanda desde el enlace de navegación, entonces ese punto de navegación podría crear
hasta el número máximo. Cuando se crean varios puntos de navegación desde el mismo enlace de navegación,
esos puntos de navegación están limitados al número máximo establecido para el enlace de navegación.

Los enlaces de navegación también establecen un tiempo de retención para las apps generadas. Las apps a
demanda se eliminan automáticamente al expirar su período de retención.

5.3 Publicar apps a demanda (Windows)


La mayoría de usuarios usarán las apps a demanda y de selección después de haberlas publicado. Cuando las
apps de selección se publican en un stream, los usuarios que tienen los permisos adecuados de acceso a ese
stream pueden utilizarlas para realizar selecciones agregadas y generar apps demanda desde los puntos de
navegación incluidos con las apps de selección. Al igual que con todas las apps publicadas, estas no se pueden
modificar tras haberlas publicado. Para agregar puntos de navegación, por ejemplo, el usuario tendría que
hacer una copia de la app de selección.

En muchos casos, los usuarios solo utilizan apps generadas a demanda. Cada app generada se puede publicar
por separado. De hecho, el enlace de navegación de la app puede especificar que las apps generadas a partir de
ella se publiquen automáticamente en un stream específico. A continuación, los usuarios exploran los
segmentos seleccionadas de datos cargados con las apps generadas a demanda en el stream en el que se ha
publicado la app.

5.4 Compartir apps a demanda (Kubernetes)


Puede compartir apps de selección a demanda en su espacio personal o en un espacio compartido. En primer
lugar, debe publicar las hojas de las apps de selección y plantillas, y después debe compartir la app de selección.
Los usuarios con los que se haya compartido podrán entonces acceder a esta app de selección. Estos usuarios
podrán acceder a los puntos de navegación en esas apps. Por ejemplo, pueden generar una app a demanda
desde la barra de navegación de apps. No se pueden crear ni compartir apps a demanda en espacios
compartidos.

Gestión de datos - Qlik Sense, June 2019 180


5   Gestionar grandes fuentes de datos big data con apps a demanda

5.5 Ventajas de las apps a demanda


Las apps a demanda ayudan a los usuarios de empresa y a los departamentos de TI a extraer valor de los
grandes entornos de datos de múltiples maneras. Las apps a demanda:

l Proporcionan a los usuarios una experiencia tipo "lista de la compra" que les permite poblar sus
aplicaciones interactivamente con un subconjunto de datos, tales como período de tiempo, segmento de
cliente o geografía.
l Proporcionan funcionalidad completa Qlik Sense a un subconjunto latente alojado en la memoria.
A diferencia de esto, Direct Discovery, que también puede administrar grandes fuentes de datos, no
mantiene todos los datos relevantes en la memoria. Con Direct Discovery, los datos de la medida residen
en la fuente hasta la ejecución.
l Permiten que el personal TI controle la magnitud de una app e invoquen aplicaciones basadas en el
volumen de datos o en las selecciones dimensionales.
l Proporcionan acceso a fuentes de datos que no sean SQL, como Teradata Aster, MapR, SAP BEx, y la
función PLACEHOLDER en SAP HANA.
La realización de consultas no SQL está en contraste con Direct Discovery, que solo se puede utilizar con
orígenes de datos SQL.
l Permiten SQL personalizable y generación de script de carga.
l Permiten acceso de sección en todos los casos.

5.6 Limitaciones
No es posible usar Qlik NPrinting con apps a demanda.

5.7 Crear una app de selección a demanda


Una app de selección a demanda ofrece los medios para seleccionar subconjuntos de conjuntos de datos muy
extensos para que Qlik associative engine pueda hacer asociaciones de manera eficaz y eficiente. En entornos
con volúmenes de datos muy extensos, le recomendamos que la app de selección cargue solo un nivel modesto
de granularidad de dimensión. Por ejemplo, una app de selección cuyos datos se basen en datos de ventas
agregados por trimestre, región y categoría de producto podría utilizar una sentencia SQL SELECT como la
siguiente:

SELECT SUM(S.UNIT_COST) AS TOTAL_UNIT_COST, SUM(S.QUANTITY) AS TOTAL_QUANTITY, SUM(S.UNIT_PRICE *


S.QUANTITY) AS TOTAL_SALE, SUM( (S.UNIT_PRICE - S.UNIT_COST) * QUANTITY) AS TOTAL_PROFIT, SUM(1) AS
TOTAL_LINE_ITEMS, S.REGION, S.YEARQUARTER, S.PRODCAT, FROM SALE_DETAIL S GROUP BY S.REGION,
S.YEARQUARTER, S.PRODCAT
La propiedad de la expresión de la medida a demanda generalmente se basa en un resultado agregado
calculado a partir de una consulta SQL GROUP BY utilizada para cargar los datos. Como la app de selección
utiliza una consulta GROUP BY para agregar los registros SALE_DETAIL, debe usarse una función de
agregación, en este caso SUM, en los campos de medida de UNIT_COST, QUANTITY y los valores calculados de
TOTAL_SALE y TOTAL_PROFIT.

Gestión de datos - Qlik Sense, June 2019 181


5   Gestionar grandes fuentes de datos big data con apps a demanda

SUM(1) AS TOTAL_LINE_ITEMS ofrece una forma de medir con precisión el número total de líneas de pedido
de venta para cada combinación distinta de región, trimestre y categoría de producto. Cuando se crea un
enlace para producir apps a demanda, se debe proporcionar una expresión de medida como forma de
controlar el número de registros cargados en las aplicaciones a demanda. En el ejemplo SALE_DETAIL, cuando
un usuario selecciona múltiples categorías de productos, regiones y/o trimestres, se puede calcular una suma
para que TOTAL_LINE_ITEMS determine si la selección supera o no el límite de registro para la app a demanda.

Hay un ejemplo de app de selección a demanda incluido en la instalación de Qlik Sense Enterprise
on Windows en ProgramData\Qlik\Examples\OnDemandApp\sample. Esta funcionalidad no está
disponible en Kubernetes.

Los límites de registro se especifican cuando la app de selección se vincula a una app de plantilla para crear un
enlace de navegación de app. Cada enlace de navegación de app tiene un límite de registros. Se pueden crear
múltiples enlaces de navegación desde la app de selección. Normalmente los enlaces de navegación de apps
múltiples se crean enlazando una app de selección con distintas apps de plantilla a fin de producir múltiples
vistas de los datos.

Los enlaces de navegación de app a demanda individuales se pueden incluir en una app de selección para su
publicación. Una vez incluido en la app de selección, un enlace de navegación de app se utiliza para crear uno o
más puntos de navegación de app que permiten a los usuarios de hojas específicas crear apps a demanda
basadas en la app de plantilla de ese enlace.

5.8 Crear una app de plantilla a demanda


Una app de plantilla a demanda es una app Qlik Sense normal pero con una importante diferencia: su script de
carga contiene expresiones de enlace a los datos utilizadas para formular las consultas efectuadas en las
fuentes de datos. Estas expresiones de enlace a los datos se utilizan en el tiempo de generación de una app a
demanda para leer valores del estado de selección de la app de selección y vincularlas al script de la app de
plantilla para que la aplicación generada se cargue con un subconjunto de datos controlado por el usuario.

La app de plantilla normalmente se conecta a la misma fuente de datos que la app de selección. El script de
carga de una app de selección generalmente carga datos agregados para reducir los volúmenes de datos y al
mismo tiempo ofrece visualizaciones interactivas de dimensiones y medidas importantes. El script de carga de
una app de plantilla utiliza consultas que cargan un subconjunto controlado de datos más granulares.

Una app de plantilla a demanda no carga los datos directamente. Si intenta cargar datos desde la
app de plantilla, se producirá un error. La conexión de la app de plantilla debe ser válida, pero para
probar si la conexión funciona correctamente debe generar una app a demanda. Cuando se genera
una app a demanda, el servicio de apps a demanda modifica la secuencia del script de carga para
cargar el estado de selección de la app de selección a demanda. Si la app a demanda se genera sin
errores, entonces sabrá que la conexión en la app de plantilla funciona correctamente.

Gestión de datos - Qlik Sense, June 2019 182


5   Gestionar grandes fuentes de datos big data con apps a demanda

Tenga en cuenta el tamaño de sus apps al desarrollar apps de plantilla a demanda en Kubernetes.
En función de su despliegue, puede haber límites en el almacenamiento o el uso de una gran
cantidad de almacenamiento puede provocar que el despliegue de la nube aumente de tamaño.
Póngase en contacto con el administrador del sistema para obtener más información.

Estructura de una app de plantilla


Una app de plantilla está vinculada a una app de selección que utiliza un enlace de navegación de app a
demanda. El enlace de navegación de aplicaciones incluye propiedades que controlan el número de registros
consultados cuando la app a demanda se carga con datos. El script de carga de la app de plantilla contiene
expresiones de enlace de datos que especifican qué datos de campos de la app de selección se utilizan para
formular las consultas emitidas al cargar datos en la app a demanda.

Hay un ejemplo de app de plantilla a demanda incluido en la instalación de Qlik Sense Enterprise on
Windows en ProgramData\Qlik\Examples\OnDemandApp\sample. Esta funcionalidad no está
disponible en Kubernetes.

Las expresiones de enlace de datos tienen la forma siguiente:

$(od_FIELDNAME)

El prefijo od_ se utiliza para vincular el estado de selección de la app de selección con el script de carga de la
app a demanda, el cual se crea al copiar la app de la plantilla. La parte de la expresión de enlace de datos que
sigue al prefijo od_ debe ser un nombre que coincida con un campo en la app de selección. Cuando se genera la
app a demanda, el estado de selección actual de la app de selección se usa para obtener los valores deseados
para enlazar para cada campo. Cada instancia de una expresión $(od_FIELDNAME) en el script de carga de la
app a demanda recién creada se reemplaza por la lista de valores seleccionados para el campo
correspondiente en el estado de selección de la app de selección.

Para ser una sintaxis SQL válida, la sentencia SELECT de la app de plantilla para filtrar por múltiples valores
debe usar una cláusula IN. La práctica recomendada es escribir una subrutina para crear la claúsula WHERE
correcta:

SUB ExtendWhere(Name, ValVarName) LET T = Name & '_COLNAME'; LET ColName = $(T); LET Values =
$(ValVarName); IF len(Values) > 0 THEN IF len(WHERE_PART) > 0 THEN LET WHERE_PART = '$(WHERE_PART)
AND $(ColName) IN ( $(Values) )'; ELSE LET WHERE_PART = ' WHERE $(ColName) IN ( $(Values) )'; ENDIF
ENDIF END SUB;
Antes de llamar a la subrutina ExtendWhere debe establecer la variable WHERE_PART.

SET WHERE_PART = '';


Si desea que la sentencia SQL tenga una cláusula WHERE inmutable además de las cláusulas que la app de
selección insertará, inserte una cláusula 'WHERE <condition>' en la sentencia SET. O si no, utilice la sentencia
SET simple.

A continuación un ejemplo de cómo se utiliza la subroutina ExtendedWhere:

Gestión de datos - Qlik Sense, June 2019 183


5   Gestionar grandes fuentes de datos big data con apps a demanda

FOR EACH fldname IN 'ORIGIN', 'DEST', 'YEAR', 'QUARTER', 'ORIGIN_STATE_ABR', 'DEST_STATE_ABR' LET
vallist = $(fldname); WHEN (IsNull(vallist)) LET vallist = ''; IF len(vallist) > 0 THEN CALL
ExtendWhere('$(fldname)','vallist'); ENDIF NEXT fldname
La lista de nombres de campo debe coincidir con los nombres de los campos utilizados en cada enlace de
campo creado.

Una vez que se ha generado la lista de valores para cada campo, se puede escribir una sentencia SELECT. Por
ejemplo:

SQL SELECT "MKT_ID", "YEAR", "QUARTER", "ORIGIN", "ORIGIN_STATE_ABR", "DEST", "DEST_STATE_ABR",


"TICKET_CARRIER", "FARE_CLASS", "PASSENGERS", "DISTANCE", 1 AS "FLIGHT_COUNT" FROM
"SAPH7T"."/QT/AIRPORT_FACT" $(WHERE_PART);
La parte $(WHERE_PART) de la sentencia SELECT se expandirá hasta incluir la cláusula WHERE generada por la
ejecución del bucle FOR-NEXT ilustrado arriba. La lista de expresiones de columna que siguen a la palabra clave
SELECT se debe modificar para que coincida con las columnas de la tabla de su base de datos específica.

Evite utilizar los nombres de campos del modelo de app de plantilla cuando cree variables de enlace
de apps a demanda. Las variables definidas en el script están disponibles en el modelo de app de
plantilla al que se hace referencia al crear visualizaciones de datos. La elección de variables de
enlace de apps a demanda que no se solapen con los campos del modelo evitará confundir de
forma no intencionada entre los campos del modelo de la app de plantilla y las variables de
vinculación de apps a demanda en el script de carga de datos. Una buena práctica es establecer un
prefijo para variables de vinculación de apps a demanda. Por ejemplo, use X_ORIGIN en vez de
ORIGIN.

Inicio de sesión único (SSO)


Las apps a demanda pueden utilizar single sign-on (SSO) con fuentes de datos compatibles con SSO. El motor y
la fuente de datos deben configurarse para permitir SSO.

Esta funcionalidad no está disponible en Kubernetes.

Una vez que el motor y la fuente de datos se han configurado para SSO, la app de plantilla debe habilitar SSO
agregando la sintaxis siguiente al script de la app de plantilla:

///!ODAG_SSO
El servicio On-Demand App Service analiza el script cuando se genera una app a demanda y cada vez que se
vuelve a cargar.

Cuando una app a demanda se carga con SSO,la identidad del usuario final se envía a la fuente de datos. El
usuario final debe tener acceso a las fuentes utilizadas en las conexiones de datos de la app de plantilla. Solo se
cargan los datos a los que el usuario tiene acceso en esas fuentes, incluso si se selecciona un conjunto de datos
más grande.

Gestión de datos - Qlik Sense, June 2019 184


5   Gestionar grandes fuentes de datos big data con apps a demanda

Las apps a demanda generadas a partir de apps de plantilla que se usan single sign-on (SSO) no se
pueden publicar.

Cargar nodos para apps de plantilla


Los administradores pueden controlar dónde se cargan las apps a demanda en un entorno de varios nodos
estableciendo reglas de equilibrio de carga en apps de plantilla. Cuando se establece una regla de equilibrio de
carga, todas las apps generadas a partir de enlaces a la app de plantilla se cargarán de acuerdo con la regla
que se aplica a la app de plantilla.

Esta funcionalidad no está disponible en Kubernetes.

Expresiones de enlace en apps de plantilla a demanda


Los enlaces de datos en una app de plantilla especifican qué datos de su correspondiente app de selección se
utilizan para formular las consultas emitidas al cargar datos en una app a demanda.

La forma básica de las expresiones de enlace--$(od_FIELDNAME) --se puede modificar para refinar las
selecciones y asegurarse de que la app de plantilla cargue los datos correctamente.

Las apps de plantilla creadas originalmente con la extensión Qlik Sense para On-demand App
Generation deben cambiarse para utilizar el enfoque ilustrado a continuación para enlazar una
gran cantidad de selecciones de un campo.

Enlazar un gran número de selecciones desde un campo


El motor Qlik associative engine limita la cantidad de valores que se pueden concatenar juntos en una sola
sentencia LET. Para evitar la limitación, una sentencia INLINE LOAD se puede usar para construir de manera
eficiente una lista de valores separados por comas.

Primero debe crear una subrutina de script para procesar una tabla INLINE.

SUB BuildValueList(VarName, TableName, ColName, QuoteChrNum) IF $(QuoteChrNum) = 0 THEN LET LOADEXPR


= 'Concat($(ColName),' & chr(39) & ',' & chr(39) & ') AS CombinedData'; ELSE LET CHREXPR = ' chr(' &
'$(QuoteChrNum)' & ') '; LET LOADEXPR = 'Concat( $(CHREXPR) & $(ColName) & $(CHREXPR)' & ',' & chr
(39) & ',' & chr(39) & ') AS CombinedData'; ENDIF _TempTable: LOAD $(LOADEXPR) Resident
$(TableName); Let vNoOfRows = NoOfRows('_TempTable'); IF $(vNoOfRows)> 0 THEN LET $(VarName) = Peek
('CombinedData',0,'_TempTable'); ENDIF drop table _TempTable; drop table '$(TableName)'; END SUB;

Las llamadas a la subrutina BuildValueList deben utilizar valores específicos para el parámetro
QuoteChrNum. Cuando el campo procesado por la subrutina es numérico, el parámetro debe fijarse
en 0. Para los datos de caracteres, el parámetro debe fijarse en 39.

Gestión de datos - Qlik Sense, June 2019 185


5   Gestionar grandes fuentes de datos big data con apps a demanda

El enlace debe escribirse utilizando una tabla INLINE para crear una estructura para los valores de campo que
se cargarán independientemente del número de valores.

SET ORIGIN=''; OdagBinding: LOAD * INLINE [ VAL $(odso_ORIGIN){"quote": "", "delimiter": ""} ]; SET
ORIGIN_COLNAME='ORIGIN'; CALL BuildValueList('ORIGIN', 'OdagBinding', 'VAL', 39);
La expresión $(od_ORIGIN) {"quote": "", "delimiter": "") será reemplazada por una lista de valores de campo
ORIGIN desde la app de selección, separados por saltos de línea. Si el campo ORIGIN contiene los tres valores
BOS, JFK, ORD, entonces la tabla expandida INLINE presentará el siguiente aspecto:

SET ORIGIN=''; OdagBinding: LOAD * INLINE [ VAL BOS JFK ORD ]; SET ORIGIN_COLNAME='ORIGIN'; CALL
BuildValueList('ORIGIN', 'OdagBinding', 'VAL', 39);
El valor de la variable ORIGIN que sigue a la llamada a BuildValueList será:

'BOS','JFK’,'JFK'

Enlazar valores opcionales y excluidos


A veces es necesario crear una condición de filtro en la consulta del script de la app de plantilla a demanda
usando campos que no son directamente seleccionables en la app de selección. Por ejemplo, los registros de
ventas podrían usar un código de región como REGION_CODE, mientras que la app de selección usa un campo
REGION_NAME más reconocible para hacer selecciones de región. La app de selección puede tener un modelo
que use una tabla aparte para asociar REGION_CODE con REGION_NAME, de modo que los usuarios puedan
seleccionar valores desde REGION_NAME para controlar el estado de selección.

Si bien la selección de valores de REGION_NAME ocasiona que esos valores se coloquen en el estado
seleccionado, los valores de REGION_CODE están solo en el estado opcional, es decir, blanco en lugar de verde.
Además, si el diseño de las hojas de la app de selección excluye REGION_CODE de su conjunto de paneles de
filtrado, no hay forma de que la expresión de enlace $(od_REGION_CODE) en el script de la app a demanda se
expanda a la lista de regiones seleccionadas, porque los valores REGION_CODE nunca se seleccionarán
realmente, es decir, nunca se volverán de color verde.

Para manejar esta situación, existe una sintaxis adicional que controla con mayor precisión qué valores de
estado de selección se utilizan en cada enlace de datos. El prefijo od_ en la parte del nombre de campo en cada
expresión de enlace a demanda puede incluir una combinación de letras para indicar si los valores que se
utilizarán en el enlace son los tomados del estado seleccionado y del estado opcional. Las combinaciones
válidas, usando el ejemplo REGION_CODE, son:

Combinaciones válidas usando el código REGION_CODE


Patrón Expansión

$(ods_REGION_CODE) Valores seleccionados (en verde) de REGION_CODE

$(odo_REGION_CODE) Valores opcionales (en blanco) de REGION_CODE

$(odso_REGION_ Valores seleccionados u opcionales de REGION_CODE


CODE)

$(od_REGION_CODE) Igual que $(ods_REGION_CODE), solo valores seleccionados (en verde) de REGION_
CODE

Gestión de datos - Qlik Sense, June 2019 186


5   Gestionar grandes fuentes de datos big data con apps a demanda

En el caso de la app a demanda para el ejemplo de datos de ventas, la siguiente expresión de enlace de datos
garantiza que o bien los valores seleccionados o los opcionales de REGION_CODE sean incluidos en el enlace
REGION_CODE:

$(odso_REGION_CODE)

Enlazar valores numéricos


Cuando los datos que se van a enlazar a la app a demanda consisten en números en lugar de cadenas de texto,
es útil deshabilitar el entrecomillado de los campos numéricos. Por ejemplo, si los registros de ventas incluyen
una columna numérica DAY_OF_WEEK y desea que el usuario de la app de selección seleccione combinaciones
arbitrarias de DAY_OF_WEEK, aumentaría la consulta de agregación utilizada para cargar la app de selección
para que incluya DAY_OF_WEEK tanto en la lista SELECT como en la lista GROUP BY. Si se colocan comillas en
torno a los valores DAY_OF_WEEK cuando están seleccionados, podría producirse un error de consulta en
tiempo de ejecución si la base de datos no admite la conversión automática de cadena de texto a numérica.

Para manejar esta situación, hay un sufijo de sintaxis que se puede agregar al final de la parte FIELDNAME de la
expresión de enlace para obligar al enlace de campo a que utilice valores numéricos desde la app de selección
en lugar de valores de cadena de texto. El sufijo es _n como en la siguiente cláusula WHERE:

WHERE DAY_OF_WEEK IN ( $(od_DAY_OF_WEEK_n) );


Esto se expandiría a:

WHERE DAY_OF_WEEK IN ( 1,2 );

Cuando se requiere un cierto número de selecciones


En algunas situaciones, puede ser necesario que la consulta a la app a demanda contenga un número específico
o un determinado rango de valores para un campo específico. Por ejemplo, si la consulta de la app a demanda
contiene una cláusula BETWEEN para obtener todas las ventas entre una fecha de inicio y una de finalización,
la expresión de enlace para el campo YEARQUARTER puede tener una sintaxis de sufijo de [2] que requerirá
exactamente seleccionar dos valores para YEARQUARTER, como en:

$(od_YEARQUARTER)[2]
El punto de navegación de la app a demanda en la app de selección permanecerá deshabilitado siempre que no
haya exactamente dos valores de YEARQUARTER seleccionados. Aparecerá un mensaje para indicar que deben
seleccionarse exactamente dos valores de YEARQUARTER.

Las restricciones en cuanto a la cantidad de selección crean un enlace de requisito previo entre la app de
selección y la app a demanda. Esto es diferente de las expresiones de enlace que no usan restricciones de
cantidad. Por ejemplo, cuando el script de la app de plantilla contiene una expresión de enlace sin una
restricción de cantidad, como en:

$(od_MYFIELD)
no hay ningún requisito en cuanto a que la app de selección contenga un campo llamado MYFIELD ni que haya
ningún valor seleccionado de ese campo si existe. Si la app de selección no contiene un campo denominado
MYFIELD o si el usuario simplemente no hace ninguna selección, el punto de navegación de la app a demanda
aún puede habilitarse cuando se realicen otras selecciones para cumplir con la condición de valor límite de
registro.

Si por otro lado, la expresión de enlace es:

$(od_MYFIELD)[1+]

Gestión de datos - Qlik Sense, June 2019 187


5   Gestionar grandes fuentes de datos big data con apps a demanda

ahora hay dos requisitos aplicados a la app de selección:

l La app de selección debe contener un campo llamado MYFIELD.


l El usuario debe seleccionar al menos un valor para MYFIELD.

Este tipo de expresión de enlace debe usarse con cuidado porque limita qué apps de selección se pueden usar
con la app de plantilla. No debe usar esta restricción de cantidad en los enlaces de una app de plantilla a menos
que esté seguro de que desea imponer ese requisito de cantidad de selección en todas las apps de selección que
enlacen con esa app de plantilla.

Para efectuar el proceso de enlace de datos, el servicio de apps a demanda utiliza un método de sustitución de
cadenas que es insensible a los comentarios en el script. Esto significa que no debe utilizar expresiones de enlace
en los comentarios a menos que desee que esos comentarios contengan la lista de valores enlazados tras la
generación de la app.

También se pueden hacer otras restricciones en cuanto a cantidad. La tabla siguiente resume las diferentes
combinaciones que se pueden hacer en cuanto a restricciones en la cantidad de selección.

Diferentes combinaciones en cuanto a restricciones en la cantidad de selección


Tipo de restricción Requisito de selección

$(od_YEARQUARTER)[2] Deben seleccionarse exactamente 2 valores de YEARQUARTER.

$(od_YEARQUARTER)[2-4] Deben seleccionarse entre 2 y 4 valores de YEARQUARTER.

$(od_YEARQUARTER)[2+] Deben seleccionarse al menos 2 valores de YEARQUARTER.

$(od_YEARQUARTER)[2-] Se pueden seleccionar como mucho 2 valores de YEARQUARTER.

La comprobación para determinar si se han cumplido todas las restricciones de cantidad en la app
de plantilla se realiza durante el proceso de generación de la app. Si se viola una restricción de
cantidad, se rechazará la solicitud para generar la app y se mostrará un mensaje de error.

Cambiar los caracteres de entrecomillado de valor y delimitador


Cuando una lista de valores de un campo seleccionado en una app de selección a demanda se inserta en el
script de una app de plantilla, los valores van rodeados de comillas simples y separados por comas. Estos son
los caracteres predeterminados para entrecomillado y delimitadores. Estos valores se pueden cambiar en la
sintaxis añadida a la sentencia de enlace para cada campo. Por ejemplo:

$(odso_ORIGIN){"quote": "|", "delimiter": ";"}


Estos nuevos valores se utilizan después al formular la lista de valores de enlace tomados de la app de selección.
Si, por ejemplo, los valores seleccionados son los primeros tres meses del año, la lista se construiría así:

|Enero|;|Febrero|;|Marzo|
Los valores predeterminados para los caracteres de entrecomillado y delimitador funcionan para la mayoría de
las bases de datos SQL estándar. Pero podrían no funcionar para algunas bases de datos SQL y no funcionan en
el caso de numerosas fuentes de datos dinámicas como NoSQL y REST. Para esas fuentes, es necesario agregar
esta expresión de enlace a fin de cambiar los caracteres de entrecomillado y delimitador.

Gestión de datos - Qlik Sense, June 2019 188


5   Gestionar grandes fuentes de datos big data con apps a demanda

Enlazar datos que contienen comillas


Si los datos de alguno de los campos que se utilizan para enlazar variables contienen comillas sencillas o dobles,
tiene que cambiar el comportamiento predeterminado de la sentencia INLINE LOAD para que no interprete las
comillas como delimitadores de valores. Cambie el delimitador que utiliza la especificación de formato por un
carácter que no aparezca en los valores del campo que se está enlazando, como se muestra con el carácter "|"
en el siguiente ejemplo:

OdagBinding:
LOAD * INLINE [
VAL
$(odso_ORIGIN){"quote": "", "delimiter": ""}
]
(ansi, txt, delimiter is '|', embedded labels);

5.9 Construir una app a demanda


Una app a demanda carga un subconjunto de los datos que se cargan en forma agregada mediante una app de
selección. Una app a demanda se crea vinculando una app de selección a demanda a una app de plantilla a
demanda. Las apps de selección y las apps de plantilla son los pilares fundamentales de las apps a demanda.

Para construir una app a demanda, deben crearse primero las apps de selección y de plantilla que se puedan
vincular. Para vincularlas, las apps de selección y plantilla deben tener campos de datos en común que se
puedan vincular.

Una app de selección se puede vincular a varias apps de plantilla y una única app de plantilla puede vincularse
mediante varias apps de selección. Pero las expresiones de enlace de datos de la app de plantilla deben
corresponderse con campos de las apps de selección que estén vinculados con la misma.

Un enlace de navegación de una app a demanda une una app de selección con una app de plantilla. Los enlaces
de navegación de apps a demanda se crean en apps de selección. Una vez que se ha definido un enlace de
navegación, se puede agregar a la barra de Navegación de la app de la app de selección como un punto de
navegación de la app a demanda. Cada hoja de una app contiene su propia barra de Navegación de app. A
continuación, los usuarios pueden generar apps a demanda desde el punto de navegación de la app.

Ejemplo de la vista de creación de apps a demanda.

Gestión de datos - Qlik Sense, June 2019 189


5   Gestionar grandes fuentes de datos big data con apps a demanda

Se pueden generar múltiples apps a demanda, cada una con una combinación diferente de datos
seleccionados, desde el mismo punto de navegación de la app.

Se pueden agregar punteros a un solo enlace de navegación de apps a múltiples hojas en la misma app de
selección. Además, las hojas pueden tener varios puntos de navegación de app, creados a partir de múltiples
enlaces de navegación de app.

Cuando una app de selección está completa con enlaces y puntos de navegación, se pueden generar apps a
demanda.

Haga lo siguiente:

1. Abra una app de selección a demanda y seleccione Editar.


2. Seleccione los enlaces de navegación de app en el panel situado a la izquierda.
3. Haga clic en el botón Crear nuevo para abrir el cuadro de diálogo Crear nuevo enlace de
navegación de app a demanda.
4. Asigne un nombre al nuevo enlace de navegación de la app a demanda.
5. Seleccione una app de plantilla a demanda.
No todas las apps de la lista desplegable App de plantilla son apps de plantilla válidas. Debe
seleccionar una app que se haya construido como una app de plantilla y cuyas expresiones de enlace de
datos correspondan a los campos de la app de selección con la que esté trabajando. De lo contrario, las
apps a demanda generadas desde el enlace de navegación de la app producirán errores.
6. Introduzca una expresión que calcule el número total de registros de detalle que están representados por
los registros agregados accesibles por medio del estado de selección en la app de selección.
La expresión normalmente usa la función SUM para obtener un total de los registros seleccionados. El
resultado se utiliza para determinar cuándo la cantidad de datos a cargar está dentro del rango
especificado para generar la app a demanda.
7. Especifique el Recuento máximo de filas.

Gestión de datos - Qlik Sense, June 2019 190


5   Gestionar grandes fuentes de datos big data con apps a demanda

El valor de Recuento máximo de filas establece el límite superior del número de registros, calculado
por la función en la entrada de la Expresión, que puede cargar la app a demanda. Siempre que el
número de registros calculado por la expresión de cálculo de filas en la app de selección sea mayor que
el valor de Recuento máximo de filas, la app a demanda no se podrá generar. La app solo se puede
generar cuando el número de registros calculados por la expresión de cálculo de filas está en el límite
superior o por debajo del límite superior establecido por el valor de recuento máximo de filas.
Para crear la expresión utilizada para el Recuento máximo de filas, debe saber cómo se calcula el
recuento total de registros desde los campos disponibles en la app de selección.
8. Especifique el Número máximo de apps generadas.
Se pueden generar múltiples apps a demanda desde el mismo punto de navegación de la app a
demanda en la barra Navegación de app de la app de selección. La razón para generar múltiples apps
está en que cada una puede contener una selección diferente de datos. Cuando se ha generado el
número máximo de apps, el usuario que está generando apps desde el punto de navegación debe
eliminar una de las apps existentes antes de generar una nueva app a demanda.
El número máximo de apps generadas se aplica al enlace de navegación de la app a demanda. Si se
crea un punto de navegación de app a demanda desde el enlace de navegación, entonces ese punto de
navegación podría crear hasta el número máximo. Pero si se crean varios puntos de navegación desde
el mismo enlace de navegación, entonces el número total de apps a demanda generadas desde esos
puntos de navegación se limita a lo configurado en Número máximo de apps generadas.
9. Introduzca un valor numérico en el campo Tiempo de retención que defina el tiempo que las apps
generadas desde el enlace de navegación deban conservarse antes de ser eliminadas.
10. En el menú desplegable a la derecha del campo Tiempo de retención, seleccione la unidad de tiempo
para el período de retención.
Las opciones para el tiempo de retención son horas, días o Nunca expira.
Todas las apps a demanda generadas desde el enlace de navegación se conservarán de acuerdo con
esta configuración. La edad de una app a demanda generada es la diferencia entre la hora actual y la
hora de la última carga de datos. Este cálculo de la edad de una app a demanda es el mismo para apps
publicadas y no publicadas. Y si una app a demanda se publica manualmente después de haber sido
generada, el cálculo de edad sigue siendo el mismo: se basa en la última carga de datos de la app
generada.

También hay una configuración de tiempo de retención en el servicio On-Demand App


Service, la cual se aplica a las apps generadas por usuarios anónimos. Esa configuración no
afecta al tiempo de retención para los usuarios que inician sesión con su propia identidad.
Para las apps generadas por usuarios anónimos, el tiempo de retención es el más corto de
lo establecido en el parámetro Tiempo de retención en el enlace de navegación y la
configuración de On-Demand App Service, que se establece en Qlik Management Console.
Esta funcionalidad no está disponible en Kubernetes.

11. En el menú desplegable Vista predeterminada al abrir, seleccione la hoja que se mostrará primero
cuando se abran las apps generadas desde el enlace de navegación.
Puede seleccionar la Vista general de apps o una de las hojas de la app de selección desde la que se
crea el enlace de navegación.
12. a. Windows: Seleccione un stream en el menú desplegable Publicar en donde se publicarán las

Gestión de datos - Qlik Sense, June 2019 191


5   Gestionar grandes fuentes de datos big data con apps a demanda

apps generadas desde el enlace de navegación.


Debe tener permiso para publicar en el stream seleccionado. Si no tiene privilegios de publicación
en el stream seleccionado, los intentos de generar apps a demanda desde el enlace de
navegación fallarán.
Al seleccionar un stream para publicar apps generadas, debe asegurarse de que los usuarios de
la app a demanda tengan privilegios de lectura en el stream.
También puede seleccionar No publicado (guardado en el área de trabajo) para guardar
las apps generadas en el área de trabajo de los usuarios sin publicarlas.

Si los usuarios anónimos pueden usar una app de selección publicada, los enlaces de
navegación de apps a demanda deben configurarse para publicar en un stream al a
que puedan acceder los usuarios anónimos. Si las apps a demanda generadas a
partir del enlace de navegación no se publican automáticamente, los usuarios
anónimos recibirán un mensaje de error cuando intenten generar esas apps.

Una vez que se ha generado una app, se puede publicar manualmente.


b. Kubernetes: Puede compartir apps de selección a demanda en su espacio personal o en un
espacio compartido. En primer lugar, debe publicar las hojas de las apps de selección y plantillas,
y después debe compartir la app de selección. Los usuarios con los que se haya compartido
podrán entonces acceder a esta app de selección. Estos usuarios podrán acceder a los puntos de
navegación en esas apps. Por ejemplo, pueden generar una app a demanda desde la barra de
navegación de apps. No se pueden crear ni compartir apps a demanda en espacios
compartidos.
13. Haga clic en Crear y el nuevo enlace de navegación de la app a demanda aparecerá en la lista de
Enlaces de navegación de la app.
14. Arrastre el enlace de navegación de la app a demanda a la barra Navegación de app de la app de
selección.
Arrastrar el enlace de navegación de la app a la app de selección crea un punto de navegación de la app
a demanda. Las propiedades del nuevo punto de navegación de la app a demanda se muestran en el
panel situado a la derecha. Si lo desea ahí puede cambiar el nombre del punto de navegación.
15. Haga clic en Hecho en el editor de hojas.
La app de selección a demanda ya está lista para utilizarse o publicarse. Los usuarios de la app de
selección podrán generar apps a demanda desde los puntos de navegación en la barra de Navegación
de app en la app de selección.

Gestión de datos - Qlik Sense, June 2019 192


6   Conectar con fuentes de datos

6 Conectar con fuentes de datos


Qlik Sense le permite conectar con sus datos, donde quiera que estos se encuentren almacenados, gracias a una
amplia variedad de conectores Qlik y otros tipos de conexiones de datos. Cuando crea una conexión de datos,
esta se guarda en Qlik Sense, para que pueda seleccionar y cargar rápidamente datos de las fuentes de datos
que utiliza habitualmente. Conéctese a bases de datos, datos de redes sociales, archivos locales, archivos
remotos y archivos web.

6.1 Crear una conexión


Para seleccionar datos de una fuente de datos, puede crear una nueva conexión de datos, o bien utilizar una
conexión de datos previamente guardada. Puede crear conexiones de datos y acceder a las conexiones
guardadas desde:

l Añadir datos en el gestor de datos.


Añada nuevos datos a su app de forma rápida y obtenga ayuda con la creación de asociaciones.
l Conexiones de datos en el editor de carga de datos.
Seleccione datos de una conexión de datos previa o nueva, o utilice el script para cargar datos desde
una conexión de datos. También puede editar las conexiones de datos existentes.

Únicamente puede ver conexiones de datos de su propiedad, o para las que disponga de derechos
de acceso. Póngase en contacto con su administrador de sistemas de Qlik Sense para solicitar
acceso, si lo necesita.

6.2 Tipos de conexiones de datos


Qlik Sense le permite acceder a sus datos donde quiera que estos se encuentren. Están disponibles los siguientes
tipos de conexión de datos con Qlik Sense. Puede descargar conectores desde el sitio de descargas de qlik.com
para usarlos con Qlik Sense.

Muchos de los conectores que acceden a estas fuentes de datos vienen incorporados en Qlik Sense, mientras que
otros se pueden añadir. Cada tipo de conexión de datos contiene parámetros específicos que hay que
configurar.

Adjuntar archivos
Adjunte archivos de datos directamente a su app mediante arrastrar y soltar.

Qlik DataMarket

Qlik Sense Enterprise solo.

Gestión de datos - Qlik Sense, June 2019 193


6   Conectar con fuentes de datos

Seleccione datos climáticos y demográficos actuales e históricos, tipos de cambio de divisas, así como datos
empresariales, económicos y sociales.

Conectores para bases de datos

Qlik Sense Enterprise solo.

Conecte con una fuente de datos ODBC mediante conectores de bases de datos preconfigurados ODBC.

l Amazon Redshift
l Apache Drill (Beta)
l Apache Hive
l Apache Phoenix (Beta)
l Apache Spark (Beta)
l Azure SQL
l Cloudera Impala
l Google BigQuery
l IBM DB2
l Microsoft SQL Server
l MongoDB (Beta)
l MySQL Enterprise
l Oracle
l PostgreSQL
l Presto
l Sybase ASE
l Teradata

Essbase
Conecte con un conjunto de datos Essbase.

Archivos locales o en red

Qlik Sense Enterprise solo.

Conecte con un archivo local o de red para seleccionar y cargar datos.

Conexiones ODBC mediante DSN

Qlik Sense Enterprise solo.

Gestión de datos - Qlik Sense, June 2019 194


6   Conectar con fuentes de datos

Conecte con un sistema gestor de bases de datos (DBMS) mediante ODBC. Instale un driver ODBC para el DBMS
en cuestión y cree una fuente de datos DSN.

Qlik Associative Big Data Index


El selector (QABDI) de Qlik Associative Big Data Index proporciona acceso a una gran fuente de datos que está
indexada con QABDI.

REST
Conecte con una fuente de datos REST . El conector REST no está adaptado específicamente para una fuente de
datos REST y puede usarse para conectar con cualquier fuente de datos expuesta mediante la REST API.

Salesforce

Qlik Sense Enterprise solo.

Conecte con su cuenta Salesforce.com.

SAP

Qlik Sense Enterprise solo.

Cargue datos desde SAP NetWeaver.

Archivos web

Qlik Sense Enterprise only

Conecte con una fuente de datos basada en web en una URL.

Conectores de proveedores de almacenamiento web

Qlik Sense Enterprise only

Conéctese a sus datos basados en archivos de proveedores de almacenamiento web.

l Dropbox

Gestión de datos - Qlik Sense, June 2019 195


6   Conectar con fuentes de datos

Conectores de terceros
Con conectores de terceros puede conectarse a fuentes de datos que no sean admitidas directamente por Qlik
Sense. Los conectores de terceros se desarrollan mediante el QVX SDK o son suministrados por desarrolladores
externos. En una instalación estándar de Qlik Sense puede que no tenga ningún conector de terceros disponible.

6.3 ¿Dónde se almacena la conexión de datos?


Qlik Sense Repository Service almacena las conexiones en la base de datos del repositorio. En una
implementación de servidor de Qlik Sense, usted administra las conexiones de datos con la consola Qlik
Management Console. La consola Qlik Management Console le permite eliminar conexiones de datos, establecer
derechos de acceso y realizar otras tareas de administración de sistemas.

En Qlik Sense Desktop todas las conexiones se guardan en la app sin cifrar.

Puesto que las conexiones de Qlik Sense Desktop no almacenan ningún detalle relativo a nombre de
usuario, contraseña y la ruta del archivo que especificó al crear la conexión, estos datos
almacenados están disponibles en texto plano si comparte la app con otro usuario. Este hecho debe
tenerse en cuenta cuando se diseñe una app que vaya a compartirse.

6.4 Limitaciones
No es posible nombrar una conexión de datos 'DM'. Este nombre se reserva para el conector incorporado de
Qlik DataMarket.

6.5 Cargar datos desde archivos


Qlik Sense puede leer datos alojados en archivos de diversos formatos:

l Archivos de texto, donde los datos en los campos están separados por delimitadores como comas,
tabuladores o signos de punto y coma (archivos (CSV) de variables separadas por comas).
l Tablas de HTML.
l Archivos de Excel (excepto archivos de Excel protegidos mediante contraseña).
l Archivos XML.
l Archivos nativos de Qlik QVD y QVX.
l Archivos de tabla con registros de longitud fija.
l Archivos DIF (Data Interchange Format). Los archivos DIF solo se pueden cargar con el editor de carga de
datos.

Puede cargar archivos desde distintos tipos de conexión de datos.

l Carpetas de archivos locales y en red.


l La carpeta Archivos adjuntos, que no se puede eliminar ni editar, contiene archivos que se han

Gestión de datos - Qlik Sense, June 2019 196


6   Conectar con fuentes de datos

cargado y adjuntado a la app. (No disponible en Qlik Sense Desktop).


l Archivos web ubicados en una URL.

¿Cómo puedo cargar datos desde archivos?


Hay varias formas de cargar datos desde archivos:

l Añadir datos mediante Añadir datos, es la forma más rápida de cargar datos desde un archivo. Puede
cargar desde una conexión de datos previa, o conectar con una nueva fuente de datos sobre la marcha.
l Seleccionar datos desde una conexión de datos en el editor de carga de datos.
En lugar de escribir manualmente las sentencias en el editor de carga de datos, puede utilizar el diálogo
Seleccionar datos para seleccionar los datos que se cargarán.
l Cargar datos de un archivo escribiendo código de script.
Los archivos se cargan utilizando una sentencia LOAD en el script. Las sentencias LOAD pueden incluir el
conjunto completo de expresiones de script.
Para leer los datos desde otra app de Qlik Sense, puede usar una sentencia Binary.

Cargar archivos desde carpetas de archivos locales y en red.


Puede cargar archivos desde carpetas de archivos locales o en red mediante una conexión a una carpeta. Debe
realizar los ajustes siguientes en la conexión de datos.

Esta funcionalidad no está disponible en Kubernetes.

Configuraciones para la conexión de datos


Elemento
Descripción
de IU

Ruta Introduzca la Ruta a la carpeta que contiene los archivos de datos. Podemos, o bien: Seleccione
la carpeta, escriba una ruta local válida o escriba una ruta UNC.

Ejemplo de ruta local válida: C:\data\MyData\

Ejemplo de ruta UNC: \\myserver\filedir\

No se puede utilizar una unidad de red mapeada en la ruta.

Nombre Nombre de la conexión de datos.

Cargar archivos desde recursos web


Puede cargar archivos desde recursos web, como FTP, HTTP o HTTPS, con una conexión de datos de archivos
web. El archivo puede ser de cualquier tipo admitido por Qlik Sense. Debe realizar los ajustes siguientes en la
conexión de datos.

Gestión de datos - Qlik Sense, June 2019 197


6   Conectar con fuentes de datos

Esta funcionalidad no está disponible en Kubernetes.

Configuraciones para una conexión de datos de archivos web


Elemento
Descripción
de IU

URL La URL completa al archivo web con el que desea conectar, incluido el identificador de
protocolo.

Example:
http://unstats.un.org/unsd/demographic/products/socind/Dec.%202012/1a.xls

Si conecta con un archivo FTP puede que necesite usar caracteres especiales, por ejemplo : o @,
en el nombre de usuario y la parte de contraseña de la URL. En este caso necesita reemplazar
los caracteres especiales por un carácter de porcentaje y el código ASCII hexadecimal del
carácter. Por ejemplo, debe reemplazar : por '%3a' y @ por '%40'.

Nombre Nombre de la conexión de datos.

La URL fijada en la conexión de datos del archivo web es estática de forma predeterminada, pero puede ignorar
la URL mediante la configuración de especificación de formato URL is . Esto es útil si necesita cargar datos
desde URL creadas dinámicamente.

Cargar datos desde una URL creada dinámicamente


En este ejemplo queremos cargar las publicaciones del foro de las primeras 10 páginas del foro New to Qlik
Sense de Qlik Community. La página del foro contiene 20 publicaciones en cada página y el parámetro final de
la URL ,start, establece qué publicación se debe mostrar como la primera de la página. En la URL de ejemplo
aquí mostrada, la página mostrará las publicaciones que comienzan por la publicación número 20 y las
siguientes 20 publicaciones.

Esta funcionalidad no está disponible en Kubernetes.

https://community.qlik.com/community/qlik-sense/new-to-qlik-
sense/content?filterID=contentstatus%5Bpublished%5D~objecttype~objecttype%5Bthread%5D&itemView=detai
l&start=20

Con el contador i pasamos por las páginas con un step de 20 hasta 180, lo que significa que el ciclo For se
ejecuta 10 veces.

Para cargar la página, sustituimos la página de inicio por $ (i) al final de la URL en la configuración URL is.

For i = 0 to 180 step 20 LOAD Title1, "Author", F6 As Replies, Views, "Latest activity" FROM
[lib://x2] (URL IS [https://community.qlik.com/community/qlik-sense/new-to-qlik-
sense/content?filterID=contentstatus%5Bpublished%5D~objecttype~objecttype%5Bthread%5D&itemView=detai
l&start=$(i)], html, utf8, embedded labels, table is @1); Next i;

Gestión de datos - Qlik Sense, June 2019 198


6   Conectar con fuentes de datos

Esto cargará las 200 publicaciones más recientes del foro en una tabla, con título, autor, número de respuestas y
visualizaciones, así como la hora en que se registró la actividad más reciente.

Cargar datos desde hojas de cálculo de Microsoft Excel


Qlik Sense puede leer datos desde hojas de cálculo de Microsoft Excel. Puede utilizar la opción Añadir datos del
Gestor de datos, o seleccionar los datos en el Editor de carga de datos. En ambos casos puede seleccionar
determinadas áreas de una hoja, una única hoja, varias hojas seleccionadas o todas las hojas desde el archivo
de hoja de cálculo. Cada hoja se carga como una tabla aparte, excepto si tienen la misma estructura de campo,
en cuyo caso se concatenan en una tabla.

Cuando carga una hoja de cálculo de Microsoft Excel, está usando la hoja de cálculo como una
fuente de datos para las apps de Qlik Sense. Es decir, que las hojas de Microsoft Excel se convierten
en tablas en Qlik Sense, no hojas en una app de Qlik Sense.

Puede resultarle útil realizar algunos cambios en Microsoft Excel antes de cargar la hoja de cálculo.

Seleccionar datos de hojas de Microsoft Excel


Cuando selecciona datos de las hojas de Microsoft Excel, hay algunas configuraciones para ayudarle a
interpretar correctamente los datos de la tabla:

Configuración para ayudarlo a interpretar los datos de la tabla correctamente


Elemento
Descripción
de IU

Nombres Especifique si la tabla contiene Nombres de campo incluidos o Sin nombres de campo.
de campo Normalmente, en una hoja de cálculo de Excel, la primera fila contiene los nombres de campo
incluidos. Si selecciona Sin nombres de campo, los campos se denominarán A,B,C...

Tamaño Defina el número de filas que se deben omitir como cabecera de tabla, por lo general filas que
de contengan información general que no esté en un formato de columna.
cabecera

Ejemplo
La hoja de cálculo presentará el siguiente aspecto:

Hoja de cálculo
Equipo: AEJ12B - -

Fecha: 2015-10-05 09 - -

Fecha-hora Orden Operador Resultado

2015-10-05 09:22 00122344 A 52

2015-10-05 10:31 00153534 A 67

2015-10-05 13:46 00747899 B 86

Gestión de datos - Qlik Sense, June 2019 199


6   Conectar con fuentes de datos

En este caso probablemente desee ignorar las dos primeras líneas y cargar una tabla con los campos
Timestamp, Order, Operator y Yield. Para lograr esto, utilice estos parámetros:

Parámetros para ignorar las dos primeras líneas y cargar los campos
Elemento
Descripción
de IU

Tamaño 2
de
Esto significa que las dos primeras líneas se consideran datos de cabecera y se ignoran cuando
cabecera
se carga el archivo. En este caso, las dos líneas que comienzan con Machine: y Date: se ignoran,
ya que no son parte de los datos de la tabla.

Nombres Nombres de campo incluidos


de campo
Esto significa que la primera línea que se lee se utiliza como nombres de campo para las
respectivas columnas. En este caso, la primera línea que se leerá es la tercera, porque las dos
primeras líneas son datos de cabecera.

Preparar hojas de datos de Microsoft Excel para una carga más fácil con Qlik Sense
Si desea cargar hojas de cálculo de Microsoft Excel en Qlik Sense, hay muchas funciones que puede usar para
transformar y limpiar sus datos en el script de carga de datos, pero puede que sea más conveniente preparar
los datos de origen directamente en el archivo de hoja de cálculo de Microsoft Excel. En esta sección encontrará
algunos consejos que le ayudarán a preparar su hoja de cálculo para cargarla en Qlik Sense con solo un
mínimo de codificación del script.

Utilizar cabeceras de columna


Si utiliza encabezados de columna en Microsoft Excel, se seleccionarán automáticamente como nombres de
campo si selecciona Nombres de campo incluidos al seleccionar datos en Qlik Sense. También se recomienda
no incluir saltos de línea en las etiquetas y poner las cabeceras en la primera línea de la hoja.

Dar formato a los datos


Es más fácil cargar un archivo de Microsoft Excel en Qlik Sense si el contenido se organiza como datos en bruto
en una tabla. Es preferible evitar lo siguiente:

l Agregados, como sumas o contadores. Los agregados se pueden definir y calcular en Qlik Sense.
l Cabeceras duplicadas.
l Información adicional que no forma parte de los datos, como los comentarios. Lo mejor es tener una
columna para comentarios que se pueda ignorar fácilmente cuando se carga el archivo en Qlik Sense.
l Diseño de datos de tabla cruzada. Si, por ejemplo, tenemos una columna por mes, en lugar de eso sería
mejor que la columna se denominara “Mes” e introducir los mismos datos en 12 filas, una fila por mes.
Así siempre podrá verla en formato de tabla cruzada en Qlik Sense.
l Cabeceras intermedias, por ejemplo, una línea que diga “Departamento A” seguida por las líneas que
pertenecen a ese Departamento A. En su lugar, cree una cabecera de columna con el nombre
“Departamento” y rellénela con los nombres de departamento oportunos.
l Celdas combinadas. En su lugar, indique el valor de la celda en cada celda.

Gestión de datos - Qlik Sense, June 2019 200


6   Conectar con fuentes de datos

l Celdas vacías cuyo valor está implícito en el valor de la celda superior anterior. Habrá que rellenar las
celdas vacías donde el valor se repite para que cada celda contenga un valor de datos.

Usar áreas designadas


Si solo desea leer una parte de una hoja, puede seleccionar un área de columnas y filas y definirla como un área
designada en Microsoft Excel. Qlik Sense puede cargar los datos de áreas designadas, además de las hojas.

Normalmente, puede definir los datos sin procesar como un área designada y mantener todos los demás
comentarios y leyendas fuera de ese área designada. Esto facilitará la carga de datos en Qlik Sense.

Eliminar la protección con contraseña


Qlik Sense no soporta archivos protegidos con contraseña, así que necesitará eliminar la protección mediante
de la hoja de cálculo antes de mcargarla en Qlik Sense.

6.6 Cargar datos de bases de datos


Es posible cargar datos procedentes de sistemas de bases de datos comerciales en Qlik Sense mediante los
siguientes conectores:

l Conectores específicamente desarrollados para cargar datos directamente desde bases de datos a través
de drivers ODBC con licencia, sin la necesidad de conexiones DSN. Para más información, vea
Conectores de Qlik: Base de datos (solo en inglés).
l Conectores que usan la interfaz Microsoft ODBC o OLE DB. Para usar Microsoft ODBC, debe instalar un
driver compatible con su DBMS y debe configurar la base de datos como una fuente de datos ODBC en el
Administrador de fuentes de datos ODBC del Windows Panel de control.

Esta funcionalidad no está disponible en Kubernetes.

Cargar datos desde una base de datos ODBC


Hay dos formas de cargar datos desde una base de datos:

Para conectar directamente con una base de datos a través de uno de los drivers ODBC con licencia de Qlik,
consulte las instrucciones para conectores Database en el sitio de ayuda de Conectores de Qlik.

Para más información, vea Conectores de Qlik: Base de datos (solo en inglés).

Los drivers ODBC con licencia de Qlik admiten las siguientes bases de datos:

l Amazon Redshift
l Apache Drill (Beta)
l Apache Hive
l Apache Phoenix (Beta)
l Apache Spark (Beta)
l Azure SQL
l Cloudera Impala

Gestión de datos - Qlik Sense, June 2019 201


6   Conectar con fuentes de datos

l Google BigQuery
l IBM DB2
l Microsoft SQL Server
l MongoDB (Beta)
l MySQL Enterprise
l Oracle
l PostgreSQL
l Presto
l Sybase ASE
l Teradata

Para usar la interfaz de Microsoft ODBC haga lo siguiente:

1. Necesita tener una fuente de datos ODBC para la base de datos a la que desee acceder. Esto se configura
en el Administrador de fuentes de datos ODBC en el Windows Panel de control. Si aún no tiene
una fuente de datos, debe agregarla y configurarla para que apunte, por ejemplo, a una base de datos
de Microsoft Access.
2. Abra el editor de carga de datos.
3. Cree una conexión de datos ODBC que apunte a la conexión ODBC mencionada en el paso 1.
4. Haga clic en ± en la conexión de datos para abrir el cuadro de diálogo de selección de datos.

Ahora puede seleccionar datos de la base de datos e insertar el código de script necesario para cargar los datos.

ODBC
Puede acceder a un DBMS (Database Management System) a través de ODBC con Qlik Sense:

l Puede utilizar los conectores de la Database del Qlik ODBC Connector Package que son compatibles con
las fuentes ODBC más habituales. Esto le permite definir la fuente de datos en Qlik Sense sin necesidad de
usar el Microsoft Windows Administrador de fuentes de datos ODBC. Para conectar directamente
con una base de datos a través de uno de los drivers ODBC con licencia de Qlik en el ODBC Connector
Package, consulte las instrucciones para conectores Database en el sitio de ayuda de Qlik Connectors.
l Puede instalar un driver ODBC para el DBMS en cuestión y crear una fuente de datos DSN. Esto se
describe en la presente sección.

Esta funcionalidad no está disponible en Kubernetes.

Gestión de datos - Qlik Sense, June 2019 202


6   Conectar con fuentes de datos

El diálogo Crear nueva conexión (ODBC) muestra las conexiones DSN de usuario que se han
configurado. Cuando esté usando Qlik Sense Desktop, la lista de conexiones DSN muestra los drivers
ODBC incluidos en ODBC Connector Package. Se identifican por el "Qlik-" adjunto al nombre (por
ejemplo, Qlik-db2). Estos drivers no se pueden utilizar para crear una nueva conexión ODBC. Los
utilizan exclusivamente los conectores de bases de datos del ODBC Connector Package. Los drivers
ODBC de ODBC Connector Package no se muestran cuando estamos usando Qlik Sense en un
entorno de servidor.

Otra posibilidad es exportar los datos desde la base de datos a un archivo en un formato legible para Qlik Sense.

Normalmente algunos drivers ODBC vienen instalados junto con Microsoft Windows. Se pueden comprar drivers
adicionales a los minoristas de software, se encuentran en Internet o los facilita el fabricante de DBMS. Algunos
drivers se distribuyen gratuitamente.

La interfaz ODBC aquí descrita es la interfaz en el equipo cliente. Si el plan es usar ODBC para acceder a una
base de datos relacional multiusuario en un servidor de red, es posible que se necesite un software DBMS
adicional que permita a un cliente acceder a la base de datos en el servidor. Póngase en contacto con el
proveedor de DBMS para obtener más información sobre el software necesario.

Configuración de conexiones de datos ODBC


Parámetros de conexión de datos ODBC
Elemento
Descripción
de IU

DSN de Seleccione a qué tipo de DSN conectarse.


usuario
Para las fuentes DSN de usuario es necesario especificar si se va a usar un controlador de 32
DSN de
bits con Usar conexión de 32 bits.
sistema
Las conexiones DSN de sistema se pueden filtrar según sean de 32 bits o de 64 bits.

Single Puede habilitar Single Sign-On (SSO) cuando se conecte a SAP HANA .
Sign-On
Si esta opción no está seleccionada, se utilizan las credenciales de usuario del servicio Engine,
a menos que especifique unas credenciales distintas en Nombre de usuario y Contraseña.

Si se selecciona esta opción, las credenciales de usuario del servicio Engine o Nombre de
usuario/ Contraseña servirán para hacer un inicio de sesión en Windows, seguido de un
inicio de sesión posterior en SAML (SAP HANA) usando las actuales credenciales de usuario.

Nombre de Nombre del usuario con el que conectar, si la fuente de datos lo requiere.
usuario
Deje este campo vacío si desea utilizar las credenciales de usuario del servicio Engine Service,
o si la fuente de datos no requiere credenciales.

Gestión de datos - Qlik Sense, June 2019 203


6   Conectar con fuentes de datos

Elemento
Descripción
de IU

Contraseña Añada Contraseña si la fuente de datos lo requiere.

Deje este campo vacío si desea utilizar las credenciales de usuario del servicio Engine, o si la
fuente de datos no requiere credenciales.

Nombre Nombre de la conexión de datos.

Añadir drivers ODBC


Un driver ODBC para su DBMS (DataBase Management System) debe estar instalado para que Qlik Sense pueda
acceder a su base de datos. Le remitimos a la documentación del DBMS que esté utilizando para más detalles.

Un driver ODBC para su DBMS debe estar instalado para que Qlik Sense pueda acceder a su base de datos. Este
es un software externo. Por lo tanto, las instrucciones a continuación pueden variar respecto al software de
otros proveedores. Para más detalles le remitimos a la documentación del DBMS que esté usando.

Haga lo siguiente:

1. Haga doble clic en el icono Herramientas administrativas en el Panel de control.


2. Haga doble clic en el icono Orígenes de datos (ODBC) .
Se abre el diálogo Administrador de orígenes de datos ODBC .
3. Seleccione la base de datos para usar con Qlik Sense.
4. Seleccione la pestaña Drivers en el diálogo Orígenes de datos.
En la pestaña Drivers puede ver una lista de drivers ODBC instalados. Si su DBMS no figura en la lista
debe instalar un driver para el mismo. Ejecute el programa de instalación que se entrega con el driver
ODBC, por ejemplo, el programa de instalación de Microsoft ODBC.

Configuración de ODBC versiones de 64 y 32 bits


Una versión de 64 bits del sistema operativo Microsoft Windows incluye las siguientes versiones de la
herramienta Microsoft Open DataBase Connectivity (ODBC) Data Source Administrator (Odbcad32.exe):

l La versión de 32 bits del archivo Odbcad32.exe se encuentra ubicado en la carpeta


%systemdrive%\Windows\SysWOW64.
l La versión de 64 bits del archivo Odbcad32.exe se encuentra ubicado en la carpeta
%systemdrive%\Windows\System32.

Crear fuentes de datos ODBC


Debe crear una fuente de datos ODBC para la base de datos a la que desee acceder. Esto se puede hacer
durante la instalación de ODBC o en una etapa posterior.

Gestión de datos - Qlik Sense, June 2019 204


6   Conectar con fuentes de datos

Antes de comenzar con la creación de fuentes de datos, debe decidir si la fuente de datos debe ser
DSN de usuario o DSN de sistema (recomendado). Solo podrá acceder a fuentes de datos de
usuario con las credenciales de usuario correctas. En una instalación de servidor, normalmente
necesita crear fuentes de datos de sistema para poder compartir las fuentes de datos con otros
usuarios.

Haga lo siguiente:

1. Abra Odbcad32.exe.
2. Vaya a la pestaña DSN de sistema para crear una fuente de datos del sistema.
3. Haga clic en Añadir.
Aparece el cuadro de diálogo Crear nuevo origen de datos que muestra una lista de los drivers ODBC
instalados.
4. Si el driver ODBC correcto aparece en la lista, selecciónelo y haga clic en Finalizar.
Se abrirá un diálogo específico del driver de base de datos seleccionado.
5. Seleccione Driver de Microsoft Access (*.mdb, *.accdb) y haga clic en Finalizar.

Si no encuentra este driver en la lista puede descargarlo desde el sitio web de descargas de
Microsoft e instalarlo.

6. Asigne un nombre a la fuente de datos y configure los parámetros necesarios.


7. Escriba el nombre Tutorial de scripts de ODBC para la fuente de datos.
8. En Base de datos, haga clic en Seleccionar...
9. En Directorios, navegue hasta la ubicación de su archivo Sales.accdb (un archivo de ejemplo de
tutorial).
10. Cuando el archivo Sales.accdb esté visible en el cuadro de texto a la izquierda, haga clic en el mismo
para convertirlo en el nombre de la base de datos.
11. Haga clic en Aceptar tres veces para cerrar todos los cuadros de diálogo.
12. Haga clic en Aceptar.

Mejores prácticas recomendadas al usar conexiones de datos ODBC


Mover apps con conexiones de datos ODBC
Si mueve una app entre instalaciones de Qlik Sense /sitios de Qlik Sense Desktop, las conexiones de datos van
incluidas. Si la app contiene conexiones de datos ODBC, debe asegurarse de que las fuentes de datos ODBC
pertinentes existan en el nuevo despliegue también. Las fuentes de datos ODBC deben nombrarse y configurarse
de forma idéntica y apuntar a las mismas bases de datos o archivos.

Gestión de datos - Qlik Sense, June 2019 205


6   Conectar con fuentes de datos

Aspectos de seguridad relativos a la conexión a conexiones de datos ODBC basadas en


archivos
Las conexiones de datos ODBC que utilizan drivers basados en archivos expondrán la ruta al archivo de datos
conectado en la cadena de conexión. La ruta se puede exponer cuando se edite la conexión, en el cuadro de
diálogo de selección de datos o en determinadas consultas SQL.

Si esto supone un problema, se recomienda conectar con el archivo de datos usando una conexión de datos de
carpeta, si es posible.

OLE DB
Qlik Sense es compatible con la interfaz OLE DB (Object Linking and Embedding, Database) para conexiones
con fuentes de datos externas. Se puede acceder a un gran número de fuentes externas mediante OLE DB.

Esta funcionalidad no está disponible en Kubernetes.

Configuración de conexiones de datos OLE DB


Configuración de conexiones de datos OLE DB
Elemento de
Descripción
IU

Proveedor Seleccione Proveedor en la lista de proveedores disponibles. Únicamente disponible


cuando cree una nueva conexión.

Fuente de Escriba el nombre de la Fuente de datos a la que desee conectarse. Puede ser un nombre
datos de servidor o, en algunos casos, la ruta de acceso a un archivo de base de datos. Esto
depende de qué proveedor OLE DB esté usando. Únicamente disponible cuando cree una
nueva conexión.

Example:

Si seleccionó Microsoft Office 12.0 Access Database Engine OLE DB Provider, introduzca el
nombre del archivo de base de datos Access, incluida la ruta completa de archivo:

C:\Users\{user}\Documents\Qlik\Sense\Apps\Tutorial source files\Sales.accdb

Si falla la conexión a la fuente de datos, se muestra un mensaje de advertencia.

Cadena de La cadena de conexión que utilizar cuando se conecta con la fuente de datos. La cadena
conexión contiene referencias al Proveedor y a la Fuente de datos. Únicamente disponible cuando
edite una conexión.

Gestión de datos - Qlik Sense, June 2019 206


6   Conectar con fuentes de datos

Elemento de
Descripción
IU

Seguridad Con esta opción se utilizan las actuales credenciales de Windows del usuario que ejecuta el
integrada servicio Qlik Sense.
Windows

Nombre de Con esta opción necesita introducir Nombre de usuario y Contraseña para las
usuario y credenciales de acceso a la fuente de datos.
contraseña
específicos:

Nombre de Nombre del usuario con el que conectar, si la fuente de datos lo requiere.
usuario
Deje este campo vacío si utiliza Seguridad integrada Windows o la fuente de datos no
requiere credenciales.

Contraseña Añada Contraseña si la fuente de datos lo requiere.

Deje este campo vacío si utiliza Seguridad integrada Windows o la fuente de datos no
requiere credenciales.

Cargar Si desea probar la conexión, haga clic en Cargar y, a continuación, en Seleccionar base
Seleccionar de datos... para establecer la conexión de datos.
base de
datos...
Todavía podrá usar todas las demás bases de datos disponibles en la fuente de
datos al seleccionar datos desde la conexión de datos.

Nombre Nombre de la conexión de datos.

Aspectos de seguridad relativos a la conexión a conexiones de datos OLE DB


basadas en archivos
Las conexiones de datos OLE DB que utilizan drivers basados en archivos expondrán la ruta al archivo de datos
conectado en la cadena de conexión. La ruta se puede exponer cuando se edite la conexión, en el cuadro de
diálogo de selección de datos o en determinadas consultas SQL.

Si esto supone un problema, le recomendamos conectarse al archivo de datos usando una conexión de datos de
carpeta si es posible.

Lógica en bases de datos


La lógica de Qlik Sense permite incluir varias tablas simultáneamente desde una aplicación de base de datos.
Cuando existe un mismo campo en más de una tabla, las tablas se enlazan de forma lógica a través de este
campo clave.

Cuando se selecciona un valor, todos los valores que sean compatibles con las selecciones se muestran como
opcional. Todos los demás valores se muestran como excluidos.

Si se seleccionan valores de varios campos, se asume un AND lógico.

Gestión de datos - Qlik Sense, June 2019 207


6   Conectar con fuentes de datos

Si se seleccionan valores del mismo campo, se asume un OR lógico.

En algunos casos, las selecciones dentro de un campo se pueden fijar como un AND lógico.

6.7 Cargar datos desde Qlik DataMarket


Puede agregar datos de fuentes externas mediante Qlik DataMarket. Qlik DataMarket ofrece una extensa
recopilación de datos actualizados y listos para su uso, procedentes de fuentes externas y accesibles
directamente desde Qlik Sense. Qlik DataMarket ofrece datos históricos y actualizados de condiciones
meteorológicas y datos demográficos, tipos de cambio de divisa, así como indicadores empresariales,
económicos y otros datos sociales.

Esta funcionalidad no está disponible en Kubernetes.

Qlik DataMarket también ofrece conjuntos de datos de la base de datos Eurostat, incluyendo Database by
themes, Tables by themes, Tables on EU policy y Cross cutting topics.

Algunos datos de Qlik DataMarket están disponibles de forma gratuita. Los paquetes de datos marcados como
Premium están disponibles mediante una tarifa de suscripción.

Antes de poder usar los datos de Qlik DataMarket, debemos aceptar los términos y condiciones para su uso.
También, si hemos comprado una licencia para paquetes de datos premium, debemos introducir nuestras
credenciales de acceso para poder utilizar los datos en dichos paquetes. Una vez aplicadas las credenciales de
acceso, los datos premium se marcan como Con licencia.

Si acepta los términos y condiciones pero no introduce una licencia para cualquiera de los paquetes de datos
premium, los paquetes de datos premium llevan junto a ellos un botón Comprar que le permite adquirir una
licencia. El botón Comprar reemplaza a la indicación Premium.

Para más información vea Activar la licencia Qlik DataMarket .

No es necesario aceptar los términos y condiciones de Qlik DataMarket cuando usamos Qlik Sense
Desktop. Tampoco se requieren credenciales de acceso porque los paquetes de datos premium no
están disponibles en Qlik Sense Desktop.

La interfaz de usuario de DataMarket se puede bloquear mediante extensiones de navegador, como


Privacy Badger, que bloquea los anuncios y mejora la privacidad. Esto ocurre si la extensión
confunde las comunicaciones de DataMarket para seguimiento de los usuarios con un tercero. Si se
encuentra con esto, puede acceder a DataMarket excluyendo su sitio Qlik Sense de la lista de sitios
bloqueados en la extensión del navegador que está bloqueando DataMarket.

Podemos explorar los datos de Qlik DataMarket de forma aislada o integrados en nuestros propios datos.
Aumentar los propios datos internos con Qlik DataMarket a menudo lleva a sorprendentes descubrimientos..

Gestión de datos - Qlik Sense, June 2019 208


6   Conectar con fuentes de datos

Los datos de Qlik DataMarket están siempre actualizados en la fuente de la que proceden. La frecuencia con la
que se actualizan dichas fuentes de datos es variable. Los datos meteorológicos y de mercado se suelen cargar
una vez al día como mínimo, mientras que los datos poblacionales y de estadísticas públicas se suelen
actualizar con una frecuencia anual. Los principales indicadores macroeconómicos, como índices de precios,
desempleo y comercio, se publican mensualmente. Todas las actualizaciones de Qlik DataMarket por lo general
están disponibles en el mismo día.

Las selecciones de datos en Qlik Sense son persistentes, de forma que siempre se carguen los datos más
recientes disponibles en Qlik DataMarket cada vez que se recarga el modelo de datos.

La inmensa mayoría de datos en Qlik DataMarket son de carácter mundial y también específicos por países. Por
ejemplo, hay datos de población mundial disponibles para más de 200 países y territorios. Además, Qlik
DataMarket ofrece varios datos por estados y regiones de Estados Unidos y Europa.

6.8 Acceso a grandes conjuntos de datos con Direct


Discovery
Direct Discovery le permite cargar grandes conjuntos de datos de ciertas fuentes SQL que tienen estructuras
simples de esquema en estrella y combinarlas con datos en memoria. Se pueden hacer selecciones en los datos
en memoria y en los datos de Direct Discovery para ver las asociaciones en los distintos conjuntos de datos con
los colores que utiliza siempre Qlik Sense: verde, blanco y gris. Algunas visualizaciones pueden analizar los datos
de ambos conjuntos de datos de forma conjunta, aunque existen varias limitaciones en el uso de este enfoque.
No está diseñado para ser una solución en tiempo real.

Esta funcionalidad no está disponible en Kubernetes.

No se emprenderá ningún desarrollo nuevo en Direct Discovery para superar estas limitaciones.

Las apps a demanda de Qlik Sense ofrecen un enfoque más flexible para cargar y analizar fuentes de big data.

Direct Discovery amplía las capacidades asociativas del modelo de datos en memoria de Qlik Sense al ofrecer
acceso a fuentes de datos adicionales mediante una consulta agregada que asocia sin fisuras grandes conjuntos
de datos con datos en memoria. Direct Discovery mejora la capacidad del usuario para realizar análisis
asociativos en fuentes de Big Data sin limitaciones. Se pueden hacer selecciones en los datos en memoria y en
los datos de Direct Discovery para ver las asociaciones en los distintos conjuntos de datos con los colores que
utiliza siempre Qlik Sense: verde, gris y blanco. Las visualizaciones pueden analizar datos de ambos conjuntos
de datos a la vez.

Los datos de Direct Discovery se seleccionan empleando una sintaxis de script específica denominada DIRECT
QUERY. Una vez que se ha establecido la estructura Direct Discovery, los campos de Direct Discovery se pueden
utilizar junto con los datos en memoria para crear objetos Qlik Sense. Cuando se utiliza un campo de Direct
Discovery en un objeto Qlik Sense, se ejecuta automáticamente una consulta SQL en la fuente de datos externa.

Gestión de datos - Qlik Sense, June 2019 209


6   Conectar con fuentes de datos

Las apps a demanda ofrecen otro método para acceder a grandes conjuntos de datos. A diferencia de Direct
Discovery, las apps a demanda ofrecen funcionalidad plena de Qlik Sense en un subconjunto latente alojado en
la memoria.

Diferencias entre datos Direct Discovery y datos en memoria


El modelo en memoria
En el modelo en memoria de Qlik Sense, todos los valores únicos de los campos seleccionados de una tabla en el
script de carga se cargan en estructuras de campos, y los datos asociados se cargan en la tabla de forma
simultánea. Los datos de campos y los datos asociados se hallan todos en la memoria.

Una segunda tabla relacionada cargada en la memoria compartiría un campo común y esa tabla podría
añadir nuevos valores únicos al campo común, o podría compartir valores previos.

Gestión de datos - Qlik Sense, June 2019 210


6   Conectar con fuentes de datos

Direct Discovery
Cuando los campos de tabla se cargan mediante una sentencia Direct Discovery LOAD (Direct Query), se crea
una tabla similar únicamente con los campos DIMENSION. Al igual que ocurre con los campos en memoria, los
valores únicos de los campos DIMENSION se cargan en la memoria. Pero las asociaciones entre los campos se
quedan en la base de datos.

Gestión de datos - Qlik Sense, June 2019 211


6   Conectar con fuentes de datos

Los valores del campo MEASURE también se quedan en la base de datos.

Gestión de datos - Qlik Sense, June 2019 212


6   Conectar con fuentes de datos

Una vez que se ha establecido la estructura Direct Discovery, los campos Direct Discovery se pueden usar con
determinados objetos de visualización y pueden utilizarse para asociaciones con los campos en memoria.
Cuando se utiliza un campo Direct Discovery, Qlik Sense automáticamente crea la consulta SQL adecuada para
ejecutarse en los datos externos. Cuando se realizan selecciones, los valores de datos asociados de los campos
Direct Discovery se utilizan en las condiciones WHERE de las consultas a la base de datos.

Con cada selección, las visualizaciones con campos Direct Discovery se recalculan y los cálculos se realizan en la
tabla de la base de datos de origen ejecutando la consulta SQL creada por Qlik Sense. Se puede utilizar la
funcionalidad de la condición de cálculo para especificar cuándo queremos que se recalculen las
visualizaciones. Hasta que se cumpla dicha condición, Qlik Sense no envía consultas para recalcular las
visualizaciones.

Diferencias de rendimiento entre campos en memoria y campos Direct Discovery


El procesamiento en memoria siempre es más rápido que el procesamiento en las bases de datos fuente. El
rendimiento de Direct Discovery refleja el rendimiento del sistema que ejecuta la base de datos que procesa las
consultas de Direct Discovery.

Es posible utilizar las mejores prácticas estándar de bases de datos y rendimiento de consultas en Direct
Discovery. Todos los ajustes de rendimiento deberían hacerse en la base de datos fuente. Direct Discovery no

Gestión de datos - Qlik Sense, June 2019 213


6   Conectar con fuentes de datos

ofrece soporte para el ajuste del rendimiento de las consultas desde la app de Qlik Sense. Sin embargo, sí es
posible hacer llamadas paralelas asíncronas a la base de datos utilizando la capacidad de agrupación de
conexiones. La sintaxis de script de carga para configurar la capacidad de conexión directa es la siguiente:

SET DirectConnectionMax=10;

El almacenamiento en la caché de Qlik Sense también mejora la experiencia global del usuario. Vea
Almacenamiento en caché y Direct Discovery (page 215) más adelante.

El rendimiento de Direct Discovery con DIMENSION también puede mejorarse separando algunos de los
campos de las asociaciones. Esto se hace mediante la palabra clave DETACH en DIRECT QUERY. Si bien los
campos separados no se consultan en busca de asociaciones, aún forman parte de los filtros, con lo que
aceleran los tiempos de selección.

Mientras que los campos en memoria de Qlik Sense y los campos Direct DiscoveryDIMENSION poseen todos sus
datos en memoria, la manera en que se cargan afecta a la velocidad de carga de datos de la memoria. Los
campos en memoria de Qlik Sense guardan solo una copia de un valor de campo cuando hay múltiples
instancias de un mismo valor. Sin embargo, se cargan todos los datos de campo y luego los datos duplicados se
clasifican.

Los campos DIMENSION también almacenan solo una copia de un valor de campo, pero los valores duplicados
se clasifican y organizan en la base de datos antes de cargarse en la memoria. Cuando manejamos cantidades
extensas de datos, como suele ocurrir cuando usamos Direct Discovery, los datos se cargan mucho más rápido
como una carga DIRECT QUERY que con la carga SQL SELECT empleada para campos en memoria.

Diferencias entre datos en memoria y datos de bases de datos


DIRECT QUERY es sensible a mayúsculas cuando se efectúan asociaciones con datos en memoria. Direct
Discovery selecciona datos de bases de datos fuente conforme a la distinción de mayúsculas de los campos de la
base de datos consultada. Si los campos de la base de datos no son sensibles a mayúsculas, una consulta Direct
Discovery podría devolver datos que no devolvería una consulta en memoria. Por ejemplo, si los siguientes datos
existen en una base de datos que no distingue entre mayúsculas y minúsculas, una consulta Direct Discovery
sobre el valor "Red" devolverá las cuatro filas.

Tabla de ejemplo
ColumnaA ColumnaB

rojo uno

Rojo dos

rOJO tres

ROJO cuatro

Una selección en memoria de "Red," por otro lado, devolvería únicamente:

Red two

Gestión de datos - Qlik Sense, June 2019 214


6   Conectar con fuentes de datos

Qlik Sense normaliza los datos hasta tal punto que produce correspondencias en datos seleccionados que las
bases de datos no encontrarían. Como resultado, una consulta en memoria puede producir más valores de
correspondencias que una consulta de Direct Discovery. Por ejemplo, en la tabla siguiente, los valores para el
número "1" varían según la ubicación de los espacios a su alrededor:

Tabla con diferentes valores para


el número "1" según la diferente
ubicación de los espacios
ColumnaA ColumnaB

' 1' espacio_antes

'1' sin_espacio

'1 ' espacio_después

'2' dos

Si selecciona "1" en un Panel de filtrado para ColumnA, donde los datos están en memoria estándar en Qlik
Sense, las primeras tres filas se asocian:

Associated rows
ColumnA ColumnB

' 1' space_before

'1' no_space

'1 ' space_after

Si el Panel de filtrado contiene datos Direct Discovery, la selección de "1" podría asociar solo "no_space". Las
correspondencias que devuelven datos Direct Discovery dependen de la base de datos. Algunas devuelven solo
"no_space" y otras, como SQL Server, devuelven "no_space" y "space_after".

Almacenamiento en caché y Direct Discovery


El almacenamiento en la caché de Qlik Sense almacena los estados de selección de las consultas y los resultados
de las consultas asociadas en la memoria. A medida que se van haciendo los mismos tipos de selecciones, Qlik
Sense aprovecha la consulta de la caché en lugar de consultar los datos fuente. Cuando se realiza una selección
diferente, se realiza una consulta SQL en la fuente de datos. Los resultados de la caché se comparten entre
usuarios.

Example:

1. El usuario aplica la selección inicial.


SQL se pasa a la fuente de datos subyacente.
2. El usuario borra la selección y aplica la misma selección que la selección inicial.
Devuelve el resultado de la caché, SQL no se pasa a la fuente de datos subyacente.
3. El usuario aplica otra selección distinta.
SQL se pasa a la fuente de datos subyacente.

Gestión de datos - Qlik Sense, June 2019 215


6   Conectar con fuentes de datos

Se puede establecer un límite de tiempo en el almacenamiento en caché con la variable del sistema
DirectCacheSeconds. Una vez que se ha alcanzado el límite de tiempo, Qlik Sense borra la caché de los
resultados de la consulta Direct Discovery que se generaron para las selecciones anteriores. Qlik Sense consulta
entonces a la fuente de datos las selecciones efectuadas y crea la caché de nuevo según el límite de tiempo
designado.

El tiempo de caché predeterminado para los resultados de la consulta Direct Discovery es de 30 minutos, a
menos que se use la variable de sistema DirectCacheSeconds.

Tipos de campos de Direct Discovery


Dentro de Direct Discovery, hay tres tipos de campos de datos: DIMENSION, MEASURE y DETAIL. Los tipos se fijan
en los campos de datos cuando se selecciona Direct Discovery mediante la sentencia Direct Query en el script
de carga.

Todos los campos Direct Discovery se pueden utilizar en combinación con los campos en memoria.
Normalmente, los campos con valores discretos que se usarán como dimensiones se deben cargar con la
palabra clave DIMENSION, mientras que los datos numéricos que se usarán en agregaciones solo se deben
marcar como campos MEASURE.

La tabla a continuación resume las características y el uso de los tipos de campos de Direct Discovery:

Tipos de campos Direct Discovery


Tipo de campo ¿En memoria? ¿Forma asociación? ¿Se usa en expresiones de gráfico?

DIMENSION Sí Sí Sí

MEASURE No No Sí

DETAIL No No No

Campos DIMENSION
Los campos DIMENSION se cargan en la memoria y se pueden utilizar para crear asociaciones entre datos en
memoria y datos en los campos de Direct Discovery. Los campos Direct DiscoveryDIMENSION también se utilizan
para definir valores de dimensión en gráficos.

Campos MEASURE
Los campos MEASURE, por otra parte, se reconocen a un "nivel meta". Los campos MEASURE no se cargan en
memoria (no aparecen en el visor del modelo de datos). La finalidad es permitir agregaciones de los datos en
campos MEASURE para que se produzcan en la base de datos mejor que en la memoria. No obstante, los
campos MEASURE se pueden usar en expresiones sin alterar la sintaxis de la expresión. Como resultado, el uso
de los campos de Direct Discovery desde la base de datos es transparente para el usuario final.

Se pueden usar las siguientes funciones de agregación con campos MEASURE:

l Sum
l Avg
l Count

Gestión de datos - Qlik Sense, June 2019 216


6   Conectar con fuentes de datos

l Min
l Max

Campos DETAIL
Los campos DETAIL proporcionan información o detalles que puede que desee mostrar pero no utilizar en
expresiones de gráficos. Los campos designados como DETAIL normalmente contienen datos que no se pueden
agregar de modo significativo, como comentarios.

Cualquier campo puede designarse como campo DETAIL.

Fuentes de datos admitidas en Direct Discovery


Qlik Sense Direct Discovery puede utilizarse con las siguientes fuentes de datos, tanto en conexiones de 32 como
de 64 bits:

l Fuentes de datos ODBC/OLEDB - Se admiten todas las fuentes de datos ODBC/OLEDB, incluyendo SQL
Server, Teradata y Oracle.
l Conectores que admiten SQL – Conector SAP SQL, conectores QVX personalizados para
almacenamientos de datos compatibles con SQL.

Se admiten ambas conexiones, de 32 y 64 bits.

SAP
Para SAP, Direct Discovery se puede usar solo con el Qlik SAP SQL Connector, y requiere los siguientes
parámetros en las variables SET:

SET DirectFieldColumnDelimiter=' ';


SET DirectIdentifierQuoteChar=' ';

SAP utiliza OpenSQL, el cual delimita columnas con un espacio, en lugar de una coma, así que las sentencias set
anteriores ocasionan una substitución, para alojar la diferencia entre ANSI SQL y OpenSQL.

Google Big Query


Direct Discovery se puede utilizar con Google Big Query y requiere los siguientes parámetros en las variables de
conjunto:

SET DirectDistinctSupport=false;
SET DirectIdentifierQuoteChar='[]';
SET DirectIdentifierQuoteStyle='big query'

Google Big Query no admite SELECT DISTINCT o nombres de columna/tabla entre comillas y tiene una
configuración no-ANSI de entrecomillado que utiliza '[ ]'.

MySQL y Microsoft Access


Direct discovery puede usarse junto con MySQL y Microsoft Access pero puede que requiera los parámetros
siguientes en las variables de conjunto debido a los caracteres de entrecomillado empleados en estas fuentes:

SET DirectIdentifierQuoteChar='``';

Gestión de datos - Qlik Sense, June 2019 217


6   Conectar con fuentes de datos

DB2, Oracle y PostgreSQL


Direct discovery puede usarse junto con DB2, Oracle y PostgreSQL pero puede que requiera el parámetro
siguiente en las variables de conjunto debido a los caracteres de entrecomillado empleados en estas fuentes:

SET DirectIdentifierQuoteChar='""';

Sybase y Microsoft SQL Server


Direct discovery puede usarse junto con Sybase y Sybase y Microsoft SQL Server pero puede que requiera el
parámetro siguiente en las variables de conjunto debido a los caracteres de entrecomillado empleados en estas
fuentes:

SET DirectIdentifierQuoteChar='[]';

Apache Hive
Direct discovery puede usarse junto con Apache Hive, pero puede que requiera el parámetro siguiente en las
variables de conjunto debido a los caracteres de entrecomillado empleados en estas fuentes:

SET DirectIdentifierQuoteChar='';

Cloudera Impala
Direct discovery puede usarse junto con Cloudera Impala, pero puede que requiera el parámetro siguiente en las
variables de conjunto debido a los caracteres de entrecomillado empleados en estas fuentes:

SET DirectIdentifierQuoteChar='[]';
Este parámetro es obligatorio cuando se usa Cloudera Impala Connector en Qlik ODBC Connector Package.
Puede que no sea necesaio cuando se usa ODBC a través de DSN.

Limitaciones de uso de Direct Discovery


Tipos de datos que admite
No todos los tipos de datos son compatibles con Direct Discovery. Puede haber casos en los que los formatos de
datos fuente específicos deben definirse en Qlik Sense. Puede definir los formatos de datos en el script de carga
utilizando la sintaxis "SET Direct...Format". El ejemplo a continuación muestra cómo definir el formato de fecha
de la base de datos fuente que se utiliza como fuente de Direct Discovery:

Example:

SET DirectDateFormat='YYYY-MM-DD';
También hay dos variables de script para controlar cómo Direct Discovery da formato a los valores de moneda
en las sentencias SQL generadas:

SET DirectMoneyFormat (default '#.0000')


SET DirectMoneyDecimalSep (default '.')
La sintaxis de estas dos variables es la misma que para MoneyFormat y MoneyDecimalSep, pero hay dos
diferencias importantes en cuanto al uso:

Gestión de datos - Qlik Sense, June 2019 218


6   Conectar con fuentes de datos

l Este no es un formato para presentación, así que no debería incluir símbolos de moneda o separadores
de miles.
l Los valores predefinidos no se ven afectados por los datos locales sino que están vinculados a los valores.
(Los formatos locales específicos incluyen el símbolo de moneda.)

Direct Discovery puede admitir la selección de datos Unicode extendidos mediante el uso del formato estándar
SQL para literales de cadenas de caracteres extendidos (N'<cadena extendida>'), tal como requieren algunas
bases de datos, como SQL Server. Esta sintaxis se puede habilitar para Direct Discovery con la variable de script
DirectUnicodeStrings. Fijar esta variable en "true" permite el uso de "N" frente a los literales de cadena.

Seguridad
Los comportamientos siguientes que podrían afectar a las prácticas de seguridad deben tenerse en cuenta
cuando usamos Direct Discovery:

l Todos los usuarios que estén utilizando la misma app con la capacidad Direct Discovery utilizan la
misma conexión. No admite procesos de autenticación ni credenciales por usuario.
l La Sección de Acceso sólo está disponible en el modo servidor.
l La sección de acceso no es compatible con uniones de alta cardinalidad.
l Es posible ejecutar sentencias SQL personalizadas en la base de datos con una expresión de palabra
clave NATIVE, por lo que la conexión a la base de datos configurada en el script de carga debe usar una
cuenta que tenga acceso de solo lectura a la base de datos.
l Direct Discovery no tiene capacidad de registro, pero es posible usar la capacidad de seguimiento ODBC.
l Es posible llenar la base de datos de peticiones del cliente.
l Es posible obtener unos mensajes de error detallados de los archivos de registro del servidor.

Funcionalidades que no admite Qlik Sense


A causa de la naturaleza interactiva y específica de la sintaxis SQL de Direct Discovery, varias funciones no son
compatibles:

l Cálculos avanzados (análisis de conjuntos, expresiones complejas)


l Dimensiones calculadas
l Análisis comparativo (estados alternos) en los objetos que utilizan campos Direct Discovery
l Los campos Direct Discovery MEASURE y DETAIL no se admiten con la búsqueda inteligente.
l Búsqueda en campos Direct Discovery  DETAIL
l Carga binaria desde una app que está accediendo a una tabla Direct Discovery.
l Claves sintéticas en la tabla Direct Discovery
l La nomenclatura de tabla en una secuencia de comandos no se aplica a la tabla Direct Discovery.
l El caracter comodín * tras una palabra clave DIRECT QUERY en el script de carga

Example: ( DIRECT QUERY * )

l Tablas de bases de datos Oracle con columnas de tipos de datos LONG.


l Números enteros grandes en notación científica, fuera del rango [-9007199254740990,
9007199254740991]. Estos pueden ocasionar errores de redondeo y un comportamiento no definido.

Gestión de datos - Qlik Sense, June 2019 219


6   Conectar con fuentes de datos

l Esquemas de base de datos en copo de nieve


l Preparación de datos en el Gestor de datos
l Qlik Cloud no es compatible.
l Qlik Sense Enterprise on Kubernetes
l Exportar a Microsoft Excel
l La app ios móvil sin conexión no es compatible.
l Advanced Analytics Integration no es compatible.
l Extensiones y widgets no son compatibles.
l Qlik GeoAnalytics no es compatible.
l No se admite la asignación de colores a dimensiones y medidas maestras.
l Las nuevas visualizaciones incluidas en Qlik Sense June 2017 y posteriores no son compatibles:
l Diagrama de caja
l Diagrama de distribución
l Histograma
l Fuentes no SQL y sentencias que no son SQL (por ejemplo, la función PLACEHOLDER en SAP HANA).
l Los siguientes conectores no son compatibles:
l Conector Qlik Salesforce
l Conector Qlik REST
l Conector Qlik DataMarket
l Conectores Qlik Web
l Conector Qlik para uso con SAP NetWeaver
l Optimizar el SQL generado por las consultas Direct Discovery
l Las uniones de alta cardinalidad en combinación con las tablas en memoria pueden producir grandes
cláusulas IN que pueden exceder el límite del buffer SQL de la fuente de datos.

Soporte multitabla en Direct Discovery


Puede usar Direct Discovery para cargar más de una tabla o vista usando la funcionalidad de la sentencia join
de ANSI SQL. En un único gráfico, todas las medidas deben provenir de la misma tabla lógica en Qlik Sense,
pero esto puede ser una combinación de varias tablas de una fuente en la que hayan sido enlazadas mediante
sentencias join. Sin embargo, puede utilizar dimensiones que provengan de otras tablas en el mismo gráfico.

Por ejemplo, podemos enlazar las tablas cargadas con Direct Discovery usando una cláusula Where o una
cláusula Join.

l Direct Discovery se puede desplegar en un escenario de múltiples dimensiones o un único hecho, en


memoria y con grandes conjuntos de datos.
l Direct Discovery puede utilizarse con más de una tabla que cumpla uno cualquiera de los siguientes
criterios:
l La cardinalidad del campo clave en el enlace join es baja.
l La cardinalidad del campo clave en el enlace join es alta, DirectEnableSubquery se ha
configurado como verdadero y todas las tablas se han enlazado mediante Direct Discovery.

Gestión de datos - Qlik Sense, June 2019 220


6   Conectar con fuentes de datos

l Direct Discovery no es adecuado para el desarrollo en un escenario de Tercera Forma Normal (TNF) con
todas las tablas en forma Direct Discovery.

Enlazar tablas Direct Discovery con una cláusula Where


En este script de ejemplo, cargamos datos desde la base de datos AW2012. Las tablas Product y
ProductSubcategory se enlazan mediante una cláusula Where usando el campo común ProductSubCategoryID.

Product_Join:
DIRECT QUERY
DIMENSION
[ProductID],
[AW2012].[Production].[Product].[Name] as [Product Name],
[AW2012].[Production].[ProductSubcategory].[Name] as [Sub Category Name],
Color,
[AW2012].[Production].[Product].ProductSubcategoryID as [SubcategoryID]
MEASURE
[ListPrice]
FROM [AW2012].[Production].[Product],
[AW2012].[Production].[ProductSubcategory]
WHERE [AW2012].[Production].[Product].ProductSubcategoryID =
[AW2012].[Production].[ProductSubcategory].ProductSubcategoryID ;

Enlazar tablas Direct Discovery con cláusulas Join On


También podemos utilizar cláusulas Join On para enlazar tablas de Direct Discovery. En esta sentencia de
ejemplo unimos la tabla SalesOrderHeader con la tabla SalesOrderDetail mediante el campo SalesOrderID y
también unimos la tabla Customer con la tabla SalesOrderHeader mediante el campo Customer ID.

En este ejemplo, crearemos medidas a partir de la misma tabla lógica, lo que significa que podemos utilizarlas
en el mismo gráfico. Por ejemplo, puede crear un gráfico con SubTotal y OrderQty como medidas.

Sales_Order_Header_Join:
DIRECT QUERY
DIMENSION
AW2012.Sales.Customer.CustomerID as CustomerID,
AW2012.Sales.SalesOrderHeader.SalesPersonID as SalesPersonID,
AW2012.Sales.SalesOrderHeader.SalesOrderID as SalesOrderID,
ProductID,
AW2012.Sales.Customer.TerritoryID as TerritoryID,
OrderDate,
NATIVE('month([OrderDate])') as OrderMonth,
NATIVE('year([OrderDate])') as OrderYear
MEASURE
SubTotal,
TaxAmt,
TotalDue,
OrderQty
DETAIL
DueDate,
ShipDate,
CreditCardApprovalCode,
PersonID,
StoreID,

Gestión de datos - Qlik Sense, June 2019 221


6   Conectar con fuentes de datos

AccountNumber,
rowguid,
ModifiedDate
FROM AW2012.Sales.SalesOrderDetail
JOIN AW2012.Sales.SalesOrderHeader
ON (AW2012.Sales.SalesOrderDetail.SalesOrderID =
AW2012.Sales.SalesOrderHeader.SalesOrderID)
JOIN AW2012.Sales.Customer
ON(AW2012.Sales.Customer.CustomerID =
AW2012.Sales.SalesOrderHeader.CustomerID);

Utilizar subconsultas con Direct Discovery


Si la cardinalidad del campo clave que une la tabla es alta, es decir, contiene una gran cantidad de valores
distintos, una selección en Qlik Sense podría generar una sentencia SQL muy grande, ya que la cláusula WHERE
key_field IN puede contener una gran cantidad de valores. En este caso una posible solución sería dejar que
Qlik Sense cree subconsultas en su lugar.

Para ilustrar esto, usamos un ejemplo donde una tabla de productos (ProductTable) está vinculada a una tabla
de pedidos de venta (SalesOrderDetail) usando una identificación de producto (ProductID), con ambas tablas
usadas en modo Direct Discovery.

Creamos un gráfico con OrderMonth como dimensión y Sum(Subtotal) como medida, y un cuadro de filtro para
seleccionar Size.

Gestión de datos - Qlik Sense, June 2019 222


6   Conectar con fuentes de datos

Escenario 1: Baja cardinalidad


En este escenario, la tabla de productos contiene un número reducido de productos distintos, 266. Si hacemos
una selección en Size, Direct Discovery genera una sentencia SQL para devolver los datos, utilizando una
cláusula WHERE ProductID IN que contenga los ID de productos que coincidan con el tamaño seleccionado, en
este caso 19 productos.

Gestión de datos - Qlik Sense, June 2019 223


6   Conectar con fuentes de datos

El SQL generado presenta el siguiente aspecto:

SELECT ProductID, month([OrderDate]), SUM(OrderQty), SUM(SubTotal)


FROM SalesTable
WHERE ProductID IN ( 12, 51, 67, 81, 89, 92, 100, 108, 142, 150, 151, 162, 191, 206, 220, 222, 251,
254)
GROUP BY ProductID, month([OrderDate])

Escenario 2: Utilizar subconsultas


Si el mismo ejemplo contiene una gran cantidad de productos distintos, por ejemplo 20.000, la selección de un
filtro de dimensión, por ejemplo Size, generaría una sentencia SQL con una cláusula WHERE ProductID IN que
contiene miles de ID de productos. La sentencia resultante podría ser demasiado extensa para que lla gestione la
fuente de datos debido a limitaciones o problemas de memoria o rendimiento.

La solución está en permitir que Qlik Sense cree subconsultas en vez, configurando DirectEnableSubquery
como verdadero. La sentencia SQL generada podría presentar el siguiente aspecto:

SELECT ProductID, month([OrderDate]), SUM(OrderQty), SUM(SubTotal)


FROM SalesTable
WHERE ProductID IN
( SELECT DISTINCT "AW2012"."dbo"."PRODUCT"."PRODUCTID" WHERE "AW2012"."dbo"."PRODUCT"."SIZE" IN (3))
GROUP BY ProductID, month([OrderDate])

El tamaño de la cláusula WHERE ProductID IN ya no depende del número de claves resultantes de la selección.

Al utilizar subconsultas hemos de tener en cuenta las siguientes limitaciones:

l Sólo debemos invocar la sintaxis de subconsultas cuando seleccionemos datos que impliquen filtrar un
gráfico usando datos de otra tabla.
l La cantidad de datos dentro de las claves es el factor determinante, no el número de claves.
l Las subconsultas sólo se invocan si todas las tablas implicadas están en modo Direct Discovery. Si
filtramos el gráfico utilizando datos de una tabla incluida en el modo de memoria, se generará una
cláusula IN.

Acceso Direct Discovery de entrada


Las sentencias Direct Discovery SQL enviadas a la fuente de datos se pueden registrar en los archivos de
seguimiento de la conexión de la base de datos. Para una conexión ODBC estándar, el seguimiento se inicia con
el Administrador de origen de datos ODBC:

Gestión de datos - Qlik Sense, June 2019 224


6   Conectar con fuentes de datos

Las sentencias SQL de detalles del archivo de rastreo resultantes se generan a través de las selecciones e
interacciones del usuario.

Gestión de datos - Qlik Sense, June 2019 225


7   Ver el modelo de datos

7 Ver el modelo de datos


El visor del modelo de datos ofrece una vista general de la estructura de datos de una app. Puede obtener una
vista previa de los datos de las tablas y campos en el visor del modelo de datos. También puede crear
dimensiones y medidas sobre la marcha.

El modelo de datos muestra la estructura de datos de la app.

En el visor del modelo de datos cada tabla de datos está representada por un recuadro, con el nombre de tabla
como título y con todos los campos de la tabla listados debajo. Las asociaciones de tablas se muestran con
líneas, con una línea punteada indicando una referencia circular. Cuando seleccionamos una tabla o un campo,
se nos muestra una imagen al instante que permite ver la relación entre campos y tablas.

Puede cambiar el nivel de zoom haciendo clic en Y , Z o utilizando el control deslizante. Haga clic en ü
para restaurar el nivel de zoom a 1:1.

7.1 La barra de herramientas


En el visor del modelo de datos podemos encontrar las siguientes herramientas en la barra de herramientas
situada en la parte superior de la pantalla:

Opciones de la barra de herramientas


Elemento
Descripción
de IU

Menú global con opciones de navegación y acciones que puede realizar en su app.

Gestión de datos - Qlik Sense, June 2019 226


7   Ver el modelo de datos

Elemento
Descripción
de IU

Datos Haga clic en la pestaña para realizar tareas de datos. Por ejemplo, puede cargar datos en el
Gestor de datos o el Editor de carga de datos, o ver el modelo de datos en el Visor del
modelo de datos.

La pestaña Datos no está disponible en una app publicada, a menos que sea el propietario de
la app. En ese caso, solo puede abrir el Visor del modelo de datos.

Análisis Haga clic en la pestaña para realizar tareas de análisis. Por ejemplo, puede crear o interactuar
con tablas y gráficos.

Historia Haga clic en la pestaña para crear historias en su app.

Guardar Guarda los cambios.

⊟ Puede mostrar u ocultar la información de la app, editar la información o abrir las opciones
de la app y dar estilo a su app.

t Contraiga todas las tablas para mostrar el nombre de tabla únicamente.

å Reduzca el tamaño de todas las tablas para mostrar el nombre de tabla y todos los campos
con asociaciones a otras tablas.

s Expanda todas las tablas para mostrar todos los campos.

+ Vista de tablas internas - el modelo de datos de Qlik Sense incluidos los campos sintéticos.

7 Vista de tablas de origen - el modelo de datos de las tablas de los datos fuente.

ì Menú de formato con las siguientes opciones:

ì Diseño de cuadrícula

ó Auto formato

õ Restaurar formato
j Abre y cierra el panel de vista previa.

7.2 Mover y redimensionar tablas en el visor del modelo de


datos
Mover tablas
Podemos mover las tablas arrastrándolas al lienzo. Las posiciones de tabla se guardarán al guardar la app.

Puede bloquear el diseño de la tabla (posiciones y tamaños) haciendo clic en [ , en la parte derecha del lienzo.
Para desbloquear el diseño de la tabla, haga clic en \ .

Gestión de datos - Qlik Sense, June 2019 227


7   Ver el modelo de datos

También puede organizar el diseño automáticamente usando las opciones que hay debajo de ì en la barra
de herramientas:

Opciones para mover tablas


Elemento de IU Descripción

ì Diseño de Para organizar las tablas en una cuadrícula.


cuadrícula

ó Auto formato Organizar las tablas para que quepan en la ventana.

õ Restaurar Para volver al estado de diseño en el que se abrió por última vez el visor de
formato modelo de datos.

Redimensionar tablas
Podemos ajustar el tamaño de visualización de una tabla con la flecha de la esquina inferior derecha de la
tabla. El tamaño de presentación no se guardará al guardar la app.

También podemos usar las opciones automáticas de presentación de la barra de herramientas:

Opciones para redimensionar tablas


Elemento de IU Descripción

t Contraer todo Minimizar todas las tablas para mostrar solo el nombre de tabla.

å Mostrar campos Para reducir el tamaño de todas las tablas a la tabla y todos los campos con
enlazados asociaciones a otras tablas.

s Expandir todo Para maximizar todas las tablas y poder mostrar todos los campos de la tabla.

7.3 Vista previa de tablas y campos en el visor del modelo


de datos
En el Visor del modelo de datos, podemos obtener una vista previa de cualquier tabla de datos en un panel
situado en la parte inferior de la pantalla. La vista previa nos permite observar al instante los contenidos de una
tabla o campo. También podemos añadir dimensiones y medidas con rapidez a la app si seleccionamos un
campo.

Además, en el panel de vista previa se muestran los metadatos de la tabla o campo seleccionados.

Podemos ocultar y mostrar el panel de vista previa de dos maneras:

l Haga clic en j en la barra de herramientas.


l Haga clic en la cabecera de la Vista previa

Los datos de Direct Discovery no se muestran en la vista previa ÿ .

Gestión de datos - Qlik Sense, June 2019 228


7   Ver el modelo de datos

Visualización de la vista previa de una tabla


Haga lo siguiente:

l Haga clic en una cabecera de tabla en el visor del modelo de datos.

El panel de vista previa se mostrará, con los campos y valores de la tabla seleccionada.

Mostrar la vista previa de un campo


Haga lo siguiente:

l Haga clic en un campo de una tabla en el visor del modelo de datos.

El panel de vista previa se mostrará, con el campo seleccionado y sus valores, así como los metadatos del
campo. También podemos añadir el campo como una dimensión o medida maestra.

l Densidad es el número de registros que tienen valores que no son nulos, NULL, en este campo, en
comparación con el número total de registros de la tabla.
l Ratio de subconjunto es el número de valores distintos del campo que se encuentra en esta tabla,
comparado con el número total de valores distintos de este campo que se encuentran en otras tablas del
modelo de datos. Esto solo es relevante para campos clave.
l Si el campo está marcado con [Clave perfecta] , cada fila contiene un valor clave que es único.

Gestión de datos - Qlik Sense, June 2019 229


7   Ver el modelo de datos

7.4 Crear una dimensión maestra en el visor del modelo de


datos
Cuando esté trabajando con una app no publicada, puede crear dimensiones maestras para poder reutilizarlas.
Los usuarios de una app publicada podrán acceder a las dimensiones maestras, pero no podrán modificarlas. El
visor del modelo de datos no está disponible en una app publicada.

Haga lo siguiente:

1. En el visor del modelo de datos, seleccione un campo y abra el panel Vista previa.
2. Haga clic en Añadir como dimensión.
Se abrirá el diálogo Crear nuevas dimensiones, con el campo seleccionado. El nombre del campo
seleccionado se usa también como nombre predeterminado para la dimensión.
3. Cambie el nombre si lo desea y también puede añadir una descripción, color y etiquetas.
4. Haga clic en Añadir dimensión.
5. Haga clic en Hecho para cerrar el cuadro de diálogo.

La dimensión se guarda en la pestaña de elementos maestros del panel de activos.

Puede añadir rápidamente varias dimensiones como elementos maestros al hacer clic en Añadir
dimensión tras añadir cada dimensión. Haga clic en Hecho cuando termine.

Las tablas Direct Discovery se indican mediante ÿ en el visor del modelo de datos.

7.5 Crear una medida maestra en el visor del modelo de


datos
Cuando esté trabajando con una app no publicada, puede crear medidas maestras para reutilizarlas
posteriormente. Los usuarios de una app publicada podrán acceder a las medidas maestras, pero no podrán
modificarlas.

Haga lo siguiente:

1. En el visor del modelo de datos, seleccione un campo y abra el panel Vista previa.
2. Haga clic en Añadir como medida.
Se abrirá el diálogo Crear nueva medida, con el campo seleccionado. El nombre del campo
seleccionado se usa también como nombre predeterminado para la medida.
3. Introduzca un nombre para la medida.
4. Cambie el nombre si lo desea y también puede añadir una descripción, color y etiquetas.
5. Haga clic en Crear.

La medida se guarda en la pestaña de elementos maestros del panel de activos.

Gestión de datos - Qlik Sense, June 2019 230


8   Mejores prácticas de modelado de datos

8 Mejores prácticas de modelado de datos


Esta sección describe las distintas maneras en que podemos cargar nuestros datos en la app Qlik Sense,
dependiendo de cómo se estructuran los datos y del modelo de datos deseado.

8.1 Convertir columnas de datos en filas


Nuestros datos probablemente tendrán el siguiente aspecto, y queremos tener las cifras de ventas en un campo
aparte:

Tabla de datos original


Año Q1 Q2 Q3 Q4

2013 34 54 53 52

2014 47 56 65 67

2015 57 56 63 71

Proposed action

Utilice el prefijo Crosstable cuando cargue la tabla.

El resultado tendrá el siguiente aspecto:

La tabla tras aplicar el prefijo Crosstable


Year Quarter Sales

2013 Q1 34

2013 Q2 54

2013 Q3 53

2013 Q4 52

2014 Q1 47

... ... ...

8.2 Convertir filas de datos en columnas


Si tenemos una tabla genérica con tres campos similares a esto, y queremos que cada atributo se muestre como
una tabla aparte:

Tabla genérica con tres campos


Object Attribute Value

ball color red

Gestión de datos - Qlik Sense, June 2019 231


8   Mejores prácticas de modelado de datos

Object Attribute Value

ball diameter 25

ball weight 3

box color 56

box height 30

box length 20

box width 25

Proposed action

Cree un modelo de datos genérico utilizando el prefijo de carga Generic.

Obtendrá un modelo de datos con el siguiente aspecto:

8.3 Cargar datos que están organizados en niveles


jerárquicos, por ejemplo un diagrama de flujo de una
organización
Nuestros datos quizá estén almacenados en tablas de nodos adyacentes con el siguiente aspecto:

Tabla de nodos adyacentes


NodeID ParentNodeID Title

1 - General manager

2 1 Country manager

3 2 Region manager

Gestión de datos - Qlik Sense, June 2019 232


8   Mejores prácticas de modelado de datos

Proposed action

Cargue los datos con el prefijo Hierarchy para crear una tabla de nodos expandidos:

Tabla de nodos expandidos


NodeID ParentNodeID Title Level1 Level2 Level3

1 - General manager General manager - -

2 1 Country manager General manager Country manager -

3 2 Region manager General manager Country manager Region manager

8.4 Cargar solo registros nuevos o actualizados de una base


de datos extensa
Tengo una base de datos con una gran cantidad de registros y no quiero volver a cargar toda la base de datos
para actualizar los datos en mi app. Solo quiero cargar registros nuevos o actualizados y eliminar los registros
que se van borrando de la base de datos.

Proposed action

Implemente una solución de carga incremental utilizando archivos QVD.

8.5 Combinar datos de dos tablas con un campo común


Qlik Sense asociará automáticamente tablas que tengan un campo común, pero queremos controlar cómo se
combinan las tablas.

Proposed action : Join / Keep

Puede combinar dos tablas en una única tabla interna con los prefijos Join o Keep.

Proposed action : Correspondencia

Una alternativa para unir tablas es usar mapping, que automatiza la consulta de valores asociados en una
tabla de enlace. Esto puede reducir la cantidad de datos que mostrar.

8.6 Asociar un valor discreto con un intervalo


Tengo una tabla de valores numéricos discretos (Event), y quiero hacerla coincidir con uno o más intervalos
(Start y End).

Tabla de valores numéricos discretos (Event)


Hora Evento Comentario

00:00 0 Inicio de shift 1

01:18 1 Fin de línea

Gestión de datos - Qlik Sense, June 2019 233


8   Mejores prácticas de modelado de datos

Hora Evento Comentario

02:23 2 Reinicio de línea 50%

04:15 3 Velocidad de línea 100%

08:00 4 Inicio de shift 2

11:43 5 Fin de la producción

Tabla cono los intervalos (Start y End)


Inicio Fin Orden

01:00 03:35 A

02:30 07:58 B

03:04 10:27 C

07:23 11:43 D

Proposed action

Utilice el prefijo IntervalMatch para enlazar el campo Time con el intervalo definido por Start y End.

Si el intervalo no está definido explícitamente con inicio y fin, sino que solo lleva una fecha-hora, como se ve en
la tabla inferior, necesitaremos crear una tabla de intervalos.

Tabla con una fecha-hora de cambio


Moneda Datos de cambio Rate

EUR - 8.59

EUR 28/01/2013 8.69

EUR 15/02/2013 8.45

USD - 6.50

USD 10/01/2013 6.56

USD 03/02/2013 6.30

8.7 Manejo de valores de campo inconsistentes


Mis datos contienen valores de campo nombrados de forma inconsistente en las distintas tablas. Por ejemplo,
una tabla contiene el valor US en País mientras que otra tabla contiene United States. Esta situación impedirá
las asociaciones.

Tabla 1
País: Región

US Maryland

Gestión de datos - Qlik Sense, June 2019 234


8   Mejores prácticas de modelado de datos

País: Región

US Idaho

US New York

US California

Table 2
Country Population
United States 304
Japan 128
Brazil 192
China 1333

Proposed action

Haga una limpieza de datos utilizando una tabla de correspondencia (también denominada de enlace), eso
comparará los valores y permitirá las asociaciones correctas.

8.8 Manejo de mayúsculas inconsistentes en valores de


campo
Mis datos contienen valores de campo con un formato inconsistente en las distintas tablas. Por ejemplo, una
tabla contiene el valor single en Type, mientras que otra tabla contiene Single en el mismo campo. Esta
situación evitará las asociaciones, ya que el campo Type contendrá ambos valores, single y Single, las
mayúsculas sí cuentan.

Tabla 1
Tipo Precio

single 23

double 39

Tabla 2
Tipo Color

Single Rojo

Single Blue

Double Blanco

Double Black

Proposed action

Si cargó los datos con Añadir datos, puede arreglar esto en el gestor de datos.

Gestión de datos - Qlik Sense, June 2019 235


8   Mejores prácticas de modelado de datos

Haga lo siguiente:

1. En el gestor de datos, abra Table2 en el editor de tabla.


2. Renombre el campo Type como Table2.Type.
Si acaba de agregar la tabla con Añadir datos con perfilado de datos habilitado, es posible que el
campo ya tenga un nombre Table2.Type para evitar la asociación automática. En este caso, este
procedimiento asociará las dos tablas.
3. Cree un campo calculado usando la expresión Lower(Table2.Type) y denomínelo Type.
4. Haga clic en Cargar datos.

Table1 y Table2 deberían estar asociados ahora por el campo Type, que solo contiene valores en minúsculas,
como single y double.

Si desea utilizar otro estilo diferente, también puede lograr esto con procedimientos similares, pero recuerde
que las tablas se asociarán utilizando campos que tengan el mismo nombre.

l Para obtener todos los valores en mayúscula, como Single, cree el campo calculado Type en la tabla
Table1 en su lugar y use la expresión Capitalize(Table1.Type).
l Para obtener todos los valores en mayúscula, como SINGLE, cree el campo calculado Type en ambas
tablas, y utilice las expresiones Upper(Table1.Type) y Upper(Table2.Type) respectivamente.

8.9 Cargar datos geoespaciales para visualizar los datos en


un mapa
Tenemos datos que queremos visualizar en un mapa, por ejemplo, datos de ventas por país, o por tienda. Para
utilizar la visualización de mapa necesitamos cargar datos de punto o área.

Proposed action

Podemos cargar datos de punto o área que encajen con nuestras ubicaciones de valores de datos desde un
archivo KML o archivo Excel. Además, necesitaremos cargar el fondo del mapa.

8.10 Cargar registros nuevos y actualizados mediante la


carga incremental
Si su app contiene una gran cantidad de datos procedentes de bases de datos fuente que están continuamente
actualizándose, cargar el conjunto de datos completo puede consumir mucho tiempo. En este caso solo le
interesará cargar registros de la base de datos que sean nuevos o modificados, todos los demás datos ya
deberían estar disponibles en la app. La carga incremental, usando archivos QVD, permite lograr esto.

El proceso básicamente es el siguiente:

1. Cargue datos que sean nuevos o actualizados desde la tabla fuente de la base de datos.
Este proceso es lento, pero solo cargará un número limitado de registros.
2. Cargue los datos que ya están disponibles en la aplicación desde el archivo QVD.
Se cargarán muchos registros, pero este proceso es mucho más rápido.

Gestión de datos - Qlik Sense, June 2019 236


8   Mejores prácticas de modelado de datos

3. Crear un nuevo archivo QVD.


Este es el archivo que utilizará la próxima vez que haga una carga incremental.
4. Repita este mismo procedimiento para cada tabla que cargue.

Los ejemplos siguientes muestran casos en los que se utiliza la carga incremental. No obstante, podría ser
necesaria una solución más compleja, dependiendo de la estructura de la base de datos fuente y el modo de
funcionamiento.

l Anexar solo (normalmente usado para archivos de registro)


l Insertar solo (no actualizar ni eliminar)
l Insertar y actualizar (no eliminar)
l Insertar, actualizar y eliminar

Puede leer archivos QVD en modo optimizado o en modo estándar. (El método empleado es seleccionado
automáticamente por el motor Qlik Sense dependiendo de la complejidad de la operación). El modo optimizado
es aproximadamente 10 veces más rápido que el modo estándar o aproximadamente 100 veces más rápido que
cargar la base de datos de la manera habitual.

Anexar solo
El caso más simple es el de los archivos .log de registro, que solo se anexan y nunca se borran. Las condiciones
son las siguientes:

l La base de datos debe ser un archivo de registro (o algún otro archivo en el que los registros se anexen y
no se inserten ni eliminen) que esté contenido en un archivo de texto (ODBC, OLE DB u otras bases de
datos no son compatibles).
l Qlik Sense lleva un registro constante del número de registros leídos previamente y carga solo los
registros añadidos al final del archivo.

Example:

(Windows)

Buffer (Incremental) Load * From LogFile.txt (ansi, txt, delimiter is '\t', embedded labels);

Example:

(Kubernetes)

Buffer (Incremental) Load * From [lib://MyDataFiles/LogFile.txt] (ansi, txt, delimiter is '\t',


embedded labels);

Insertar solo (no actualizar ni eliminar)


Si los datos residen en una base de datos que no es un simple archivo de registro, el anexado no funcionará. No
obstante, el problema puede resolverse con un pequeño trabajo extra. Las condiciones son las siguientes:

Gestión de datos - Qlik Sense, June 2019 237


8   Mejores prácticas de modelado de datos

l La fuente de datos puede ser cualquier base de datos.


l Qlik Sense carga los registros insertados en la base de datos tras la última ejecución de script.
l Se requiere un campo ModificationTime (o similar) para que Qlik Sense reconozca qué registros son
nuevos.

Example:

(Windows)

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE
WHERE ModificationTime >= #$(LastExecTime)#
AND ModificationTime < #$(BeginningThisExecTime)#;

Concatenate LOAD PrimaryKey, X, Y FROM File.QVD;


STORE QV_Table INTO File.QVD;

Los signos hash en la cláusula SQL WHERE definen el inicio y fin de una fecha. Compruebe en el manual de su
base de datos la sintaxis de fecha correcta de su base de datos.

Example:

(Kubernetes)

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE
WHERE ModificationTime >= #$(LastExecTime)#
AND ModificationTime < #$(BeginningThisExecTime)#;

Concatenate LOAD PrimaryKey, X, Y FROM [lib://MyDataFiles/File.QVD];


STORE QV_Table INTO [lib://MyDataFiles/File.QVD];

Los signos hash en la cláusula SQL WHERE definen el inicio y fin de una fecha. Compruebe en el manual de su
base de datos la sintaxis de fecha correcta de su base de datos.

Insertar y actualizar (no eliminar)


En este caso los datos de registros previamente cargados pueden haber sido modificados entre las diversas
ejecuciones de script. Las condiciones son las siguientes:

l La fuente de datos puede ser cualquier base de datos.


l Qlik Sense carga los registros insertados o actualizados en la base de datos tras la última ejecución de
script.
l Se requiere un campo ModificationTime (o similar) para que Qlik Sense reconozca qué registros son
nuevos.
l Se requiere un campo clave primario para que Qlik Sense ordene los registros actualizados del archivo
QVD.
l Esta solución obligará a la lectura del archivo QVD en modo estándar (en lugar de optimizado), lo cual
es considerablemente más rápido que cargar toda la base de datos.

Gestión de datos - Qlik Sense, June 2019 238


8   Mejores prácticas de modelado de datos

Example:

(Windows)

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE
WHERE ModificationTime >= #$(LastExecTime)#;

Concatenate LOAD PrimaryKey, X, Y FROM File.QVD


WHERE NOT Exists(PrimaryKey);
WHERE NOT Exists(PrimaryKey);

STORE QV_Table INTO File.QVD;

Example:

(Kubernetes)

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE
WHERE ModificationTime >= #$(LastExecTime)#;

WHERE NOT Exists(PrimaryKey);


Concatenate LOAD PrimaryKey, X, Y FROM [lib://MyDataFiles/File.QVD];
WHERE NOT Exists(PrimaryKey);

STORE QV_Table INTO [lib://MyDataFiles/File.QVD];

Insertar, actualizar y eliminar


El caso más difícil de manejar se da cuando los registros han sido realmente eliminados de la base de datos
fuente entre ejecuciones de script. Las condiciones son las siguientes:

l La fuente de datos puede ser cualquier base de datos.


l Qlik Sense carga los registros insertados o actualizados en la base de datos tras la última ejecución de
script.
l Qlik Sense elimina los registros borrados de la base de datos tras la última ejecución de script.
l Se requiere un campo ModificationTime (o similar) para que Qlik Sense reconozca qué registros son
nuevos.
l Se requiere un campo clave primario para que Qlik Sense ordene los registros actualizados del archivo
QVD.
l Esta solución obligará a la lectura del archivo QVD en modo estándar (en lugar de optimizado), lo cual
es considerablemente más rápido que cargar toda la base de datos.

Example:

(Windows)

Let ThisExecTime = Now( );

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE

Gestión de datos - Qlik Sense, June 2019 239


8   Mejores prácticas de modelado de datos

WHERE ModificationTime >= #$(LastExecTime)#


AND ModificationTime < #$(ThisExecTime)#;

Concatenate LOAD PrimaryKey, X, Y FROM File.QVD


WHERE NOT EXISTS(PrimaryKey);

Inner Join SQL SELECT PrimaryKey FROM DB_TABLE;

If ScriptErrorCount = 0 then
STORE QV_Table INTO File.QVD;
Let LastExecTime = ThisExecTime;
End If

Example:

(Kubernetes)

Let ThisExecTime = Now( );

QV_Table:
SQL SELECT PrimaryKey, X, Y FROM DB_TABLE
WHERE ModificationTime >= #$(LastExecTime)#
AND ModificationTime < #$(ThisExecTime)#;

Concatenate LOAD PrimaryKey, X, Y FROM [lib://MyDataFiles/File.QVD]


WHERE NOT EXISTS(PrimaryKey);

Inner Join SQL SELECT PrimaryKey FROM DB_TABLE;

If ScriptErrorCount = 0 then
STORE QV_Table INTO [lib://MyDataFiles/File.QVD];
Let LastExecTime = ThisExecTime;
End If

8.11 Combinar tablas con Join y Keep


Un join es una operación que usa dos tablas y las combina en una sola. Los registros de la tabla resultante son
combinaciones de registros de las tablas originales, normalmente de manera que los dos registros contribuyen
a que cualquier combinación en la tabla resultante tenga un valor común para uno o varios campos comunes,
lo que se conoce como un natural join. En Qlik Sense se pueden efectuar joins en el script, produciendo tablas
lógicas.

Es posible unir tablas ya en el script. La lógica de Qlik Sense no percibirá entonces dichas tablas como
separadas, sino como el resultado de la unión (join), es decir, como si se tratara de una única tabla lógica. En
algunas situaciones esto puede ser necesario, pero tiene sus inconvenientes:

l Las tablas cargadas suelen aumentar de tamaño, lo cual hace que Qlik Sense funcione a menor
velocidad.
l Parte de la información podría perderse: la frecuencia (el número de registros) de la tabla original
podría no estar ya disponible.

Gestión de datos - Qlik Sense, June 2019 240


8   Mejores prácticas de modelado de datos

La funcionalidad de Keep, que tiene el efecto de reducir una o las dos tablas a la intersección de los datos de la
tabla antes de que las tablas se almacenen en Qlik Sense, se ha diseñado para reducir el número de casos en los
que es necesario usar uniones explícitas.

En esta documentación se utiliza el término unir (join) generalmente para referirse a las uniones
efectuadas antes de crear las tablas internas. Sin embargo, la asociación que se realiza una vez
creadas las tablas lógicas, también es un join en esencia.

Joins dentro de una sentencia SQL SELECT


Con algunos drivers de ODBC es posible hacer una unión join dentro de la sentencia SELECT. Esto es casi
equivalente a hacer una unión usando el prefijo Join.

Sin embargo, la mayoría de drivers ODBC no pueden realizar una unión externa completa (outer join
bidireccional). Solo son capaces de hacer una unión externa izquierda o derecha. Una unión externa izquierda
(o derecha) solo incluye aquellas combinaciones donde la clave de la unión figura en la tabla izquierda (o
derecha). Una unión externa completa incluye cualquier combinación. Qlik Sense realiza una unión externa
completa de forma automática.

Además, hacer joins en sentencias SELECT es mucho más complicado que hacer joins en Qlik Sense.

Example:

SELECT DISTINCTROW
[Order Details].ProductID, [Order Details].
UnitPrice, Orders.OrderID, Orders.OrderDate, Orders.CustomerID
FROM Orders
RIGHT JOIN [Order Details] ON Orders.OrderID = [Order Details].OrderID;
Esta sentencia SELECT une una tabla que contiene pedidos a una empresa ficticia, con una tabla que contiene
detalles de pedidos. Es un right outer join, lo que significa que todos los registros de OrderDetails se incluyen,
también los que tienen un OrderID que no existe en la tabla Orders. Los pedidos que existen en Orders pero no en
OrderDetails, no obstante, no se incluyen.

Join
La manera más fácil de hacer un join es mediante la inclusión del prefijo Join en el script, el cual une una tabla
interna con otra tabla designada o con la última tabla previamente creada. La unión será una unión externa,
creando todas las combinaciones posibles de valores de ambas tablas.

Example:

LOAD a, b, c from table1.csv;


join LOAD a, d from table2.csv;
La tabla interna resultante tiene los campos a, b, c y d. El número de registros difiere dependiendo de los valores
de campo de las dos tablas.

Gestión de datos - Qlik Sense, June 2019 241


8   Mejores prácticas de modelado de datos

Los nombres de los campos que se desea unir deberán ser exactamente iguales. El número de
campos que se van a unir es arbitrario. Normalmente, las tablas deberían tener uno o varios
campos en común. Si no tienen ningún campo en común, se devuelve el producto cartesiano de las
tablas. También es posible tener todos los campos en común, pero en general no tiene sentido. A
menos que se haya especificado el nombre de una tabla previamente cargada en la sentencia Join
el prefijo Join utiliza la última tabla previamente creada. Por lo tanto, el orden de las dos sentencias
no es arbitrario.

Keep
El prefijo Join explícito en el script de carga de datos realiza una unión completa de las dos tablas. El resultado
es una sola tabla. El resultado de estas uniones es, en muchos casos, una tabla muy extensa. Una de las
principales características de Qlik Sense es su capacidad de hacer asociaciones entre tablas en lugar de unirlas
(mediante join). Esto permite ahorrar mucho espacio en la memoria e incrementar la velocidad, lo que se
traduce en una flexibilidad enorme. La funcionalidad keep se ha diseñado para reducir el número de casos en
los que se tengan que usar joins explícitos.

El prefijo Keep entre dos sentencias LOAD o SELECT tiene el efecto de reducir una o las dos tablas a la
intersección de los datos de la tabla antes de que se almacenen en Qlik Sense. El prefijo Keep debe ir precedido
siempre de una de las palabras clave Inner, Left o Right. La selección de los registros desde las tablas se hace
de la misma forma que en un join correspondiente. No obstante, las dos tablas no se unen y se almacenan en
Qlik Sense como dos tablas independientes y con distintos nombres.

Inner
Los prefijos Join y Keep en el script de carga de datos pueden ir precedidos por el prefijo Inner.

Si se usa antes de Join, especifica que el join entre las dos tablas debería ser un inner join. La tabla resultante
contiene solo combinaciones ente las dos tablas, con un conjunto completo de datos de ambas partes.

Si se usa antes de Keep, especifica que las dos tablas deberían reducirse a su intersección común antes de ser
almacenadas en Qlik Sense.

Example:

En estos ejemplos utilizamos las tablas fuente Table1 y Table2:

Table 1
A B

1 aa

2 cc

3 ee

Gestión de datos - Qlik Sense, June 2019 242


8   Mejores prácticas de modelado de datos

Table2
A C

1 xx

4 yy

Inner Join
Primero hacemos un Inner Join en las tablas, lo que da como resultado a VTable, que contiene solo una fila, el
único registro que existe en ambas tablas, con datos combinados de ambas tablas.

VTable:
SELECT * from Table1;
inner join SELECT * from Table2;
VTable
A B C

1 aa xx

Inner Keep
Si en cambio realizamos un Inner Keep, todavía tendremos dos tablas. Las dos tablas por supuesto están
asociadas por el campo común A.

VTab1:
SELECT * from Table1;
VTab2:
inner keep SELECT * from Table2;
VTab1
A B

1 aa

VTab2
A C

1 xx

Left
Los prefijos Join y Keep en el script de carga de datos pueden ir precedidos por el prefijo left.

Si se usa antes de Join, especifica que el join entre las dos tablas debería ser un left join. La tabla resultante
contiene solo combinaciones entre las dos tablas, con el conjunto de datos completo de la primera tabla.

Si se usa antes de Keep, especifica que la segunda tabla debe reducirse a su intersección común con la primera
tabla antes de ser almacenada en Qlik Sense.

Example:

En estos ejemplos utilizamos las tablas fuente Table1 y Table2:

Gestión de datos - Qlik Sense, June 2019 243


8   Mejores prácticas de modelado de datos

Table1
A B

1 aa

2 cc

3 ee

Table2
A C

1 xx

4 yy

Primero realizamos un Left Join en las tablas, dando como resultado VTable, que contiene todas las filas de
Table1, combinadas con campos de las correspondientes filas en Table2.

VTable:
SELECT * from Table1;
left join SELECT * from Table2;
VTable
A B C

1 aa xx

2 cc -

3 ee -

Si en cambio realizamos un Left Keep, todavía tendremos dos tablas. Las dos tablas por supuesto están
asociadas por el campo común A.

VTab1:
SELECT * from Table1;
VTab2:
left keep SELECT * from Table2;
VTab1
A B

1 aa

2 cc

3 ee

VTab2
A C

1 xx

Gestión de datos - Qlik Sense, June 2019 244


8   Mejores prácticas de modelado de datos

Right
Los prefijos Join y Keep en el script de carga de datos pueden ir precedidos por el prefijo right.

Si se usa antes de Join, especifica que el join entre las dos tablas debería ser un right join. La tabla resultante
solo contiene combinaciones entre las dos tablas, con un conjunto completo de datos de la segunda tabla.

Si se usa antes de Keep, especifica que la primera tabla debe reducirse a su intersección común con la segunda
tabla antes de ser almacenada en Qlik Sense.

Example:

En estos ejemplos utilizamos las tablas fuente Table1 y Table2:

Table1
A B

1 aa

2 cc

3 ee

Table2
A C

1 xx

4 yy

Primero realizamos un Right Join en las tablas, dando como resultado VTable, que contiene todas las filas de
Table2, combinadas con campos de las correspondientes filas en Table1.

VTable:
SELECT * from Table1;
right join SELECT * from Table2;
VTable
A B C

1 aa xx

4 - yy

Si en cambio realizamos un Left Keep, todavía tendremos dos tablas. Las dos tablas por supuesto están
asociadas por el campo común A.

VTab1:
SELECT * from Table1;
VTab2:
right keep SELECT * from Table2;

Gestión de datos - Qlik Sense, June 2019 245


8   Mejores prácticas de modelado de datos

VTab1
A B

1 aa

VTab2
A C

1 xx

4 yy

8.12 Usar la correspondencia como alternativa a la unión


El prefijo Join en Qlik Sense es una forma potente de combinar varias tablas de datos en el modelo de datos.
Una desventaja es que las tablas combinadas pueden llegar a ser muy extensas y crear problemas de
rendimiento. Una alternativa a Join en aquellas situaciones en las que necesita buscar un valor único de otra
tabla es utilizar la asignación en su lugar. De este modo se puede evitar la carga de datos innecesarios que
ralentizan los cálculos y que puede crear errores de cálculo, ya que las uniones pueden cambiar el número de
registros en las tablas.

Una tabla de correspondencia se compone de dos columnas: un campo de comparación (entrada) y un campo
de valores de correspondencia (salida).

En este ejemplo, tenemos una tabla de pedidos (Orders) y necesitamos conocer los países de los clientes, que
están almacenados en la tabla de clientes (Customers).

Tabla de datos Orders


IDPedido FechaPedido IDTransporte Flete IDCliente

12987 2007-12-01 1 27 3

12988 2007-12-01 1 65 4

12989 2007-12-02 2 32 2

12990 2007-12-03 1 76 3

Tabla de datos Customers


IDCliente Nombre País: ...

1 DatosVentas España ...

2 BusinessCorp Italia ...

3 TechCo Alemania ...

4 Mobecho Francia ...

Para buscar el país (Country) de un cliente, necesitamos una tabla de correspondencia con el siguiente aspecto:

Gestión de datos - Qlik Sense, June 2019 246


8   Mejores prácticas de modelado de datos

Tabla de correspondencia
IDCliente País:

1 España

2 Italia

3 Alemania

4 Francia

La tabla de correspondencia, a la cual denominaremos MapCustomerIDtoCountry, se define en el script de la


siguiente manera:

MapCustomerIDtoCountry:
Mapping LOAD CustomerID, Country From Customers ;

El siguiente paso es aplicar la asignación de correspondencias, mediante el uso de la función ApplyMap al


cargar la tabla de pedidos:

Orders:
LOAD *,
ApplyMap('MapCustomerIDtoCountry', CustomerID, null()) as Country
From Orders ;

El tercer parámetro de la función ApplyMap se usa para definir qué se devolverá cuando un valor no se
encuentre en la tabla de correspondencia, en este caso Null() .

La tabla resultante tendrá el siguiente aspecto:

Tabla resultante
IDPedido FechaPedido IDTransporte Flete IDCliente País:

12987 2007-12-01 1 27 3 Alemania

12988 2007-12-01 1 65 4 Francia

12989 2007-12-02 2 32 2 Italia

12990 2007-12-03 1 76 3 Alemania

8.13 Trabajar con tablas cruzadas en el editor de carga de


datos
Una tabla cruzada es un tipo habitual de tabla, que ofrece una matriz de valores entre dos listas ortogonales de
datos de cabecera. Por lo general no es el formato de datos más óptimo si queremos asociar los datos con otras
tablas de datos.

Esta sección describe cómo podemos despivotar una tabla cruzada, es decir, transponer (o trasladar) partes de
la misma a filas utilizando el prefijo crosstable en una sentencia LOAD en el script de carga de datos.

Gestión de datos - Qlik Sense, June 2019 247


8   Mejores prácticas de modelado de datos

Despivotar una tabla cruzada con una columna cualificadora


Una tabla cruzada a menudo va precedida de una serie de columnas cualificadoras, que deben leerse de
manera directa/continua. En este caso hay una columna de cualificación, Year, y una matriz de datos de ventas
por mes.

Tabla cruzada con una columna cualificadora


Year Jan Feb Mar Apr May Jun

2008 45 65 78 12 78 22

2009 11 23 22 22 45 85

2010 65 56 22 79 12 56

2011 45 24 32 78 55 15

2012 45 56 35 78 68 82

Si esta tabla simplemente se carga en Qlik Sense el resultado será una tabla con un campo por Year y otro
campo por cada uno de los meses. Por regla general, éste no es el resultado que interesa. Probablemente
preferiríamos tener tres campos generados:

l La columna cualificadora, en este caso Year , marcada en verde en la tabla superior.


l El campo de atributo, en este caso representado por los nombres de mes Jan - Jun marcados con
amarillo. Este campo se puede denominar de forma adecuada Month.
l Los valores de la matriz de datos, marcados con azul. En este caso representan datos de ventas, por lo
que pueden denominarse Sales de forma adecuada.

Esto se logra añadiendo el prefijo crosstable a la sentencia LOAD o SELECT, por ejemplo:

crosstable (Month, Sales) LOAD * from ex1.xlsx;


Esto crea la tabla siguiente en Qlik Sense:

Tabla con el prefijo crosstable agregado a la sentencia LOAD o SELECT


Year Month Sales

2008 Ene 45

2008 Feb 65

2008 Mar 78

2008 Abr 12

2008 May 78

2008 Jun 22

2009 Ene 11

2009 Feb 23

... ... ...

Gestión de datos - Qlik Sense, June 2019 248


8   Mejores prácticas de modelado de datos

Despivotar una tabla cruzada con dos columnas cualificadoras


En este caso hay dos columnas cualificadoras a la izquierda, seguidas por las columnas matriz.

Tabla cruzada con dos columnas cualificadoras


Salesman Year Jan Feb Mar Apr May Jun

A 2008 45 65 78 12 78 22

A 2009 11 23 22 22 45 85

A 2010 65 56 22 79 12 56

A 2011 45 24 32 78 55 15

A 2012 45 56 35 78 68 82

B 2008 57 77 90 24 90 34

B 2009 23 35 34 34 57 97

B 2010 77 68 34 91 24 68

B 2011 57 36 44 90 67 27

B 2012 57 68 47 90 80 94

El número de columnas cualificadoras se puede indicar como un tercer parámetro en el prefijo crosstable de la
siguiente manera:

crosstable (Month, Sales, 2) LOAD * from ex2.xlsx;


El resultado en Qlik Sense es el siguiente:

Tabla con columnas cualificadoras enunciadas como un tercer parámetro para el prefijo crosstable
Comercial de venta Year Month Sales

A 2008 Ene 45

A 2008 Feb 65

A 2008 Mar 78

A 2008 Abr 12

A 2008 May 78

A 2008 Jun 22

A 2009 Ene 11

A 2009 Feb 23

... ... ... ...

Gestión de datos - Qlik Sense, June 2019 249


8   Mejores prácticas de modelado de datos

8.14 Bases de datos genéricas


Una base de datos genérica es una tabla en la que los nombres de campo se almacenan como valores en una
columna, mientras que los valores de los campos se almacenan en una segunda columna. Las bases de datos
genéricas se utilizan normalmente para los atributos de diferentes objetos.

Eche un vistazo al ejemplo de GenericTable a continuación. Es una base de datos genérica que contiene dos
objetos, una pelota y una caja. Obviamente hay algunos atributos que son comunes a ambos objetos, como el
color y peso, y otros que no, como el diámetro, la altura, la longitud y el ancho.

GenericTable
objecto atributo valor

bola color rojo

bola diámetro 10 cm

bola peso 100 g

recuadro color negro

recuadro alto 16 cm

recuadro largo 20 cm

recuadro peso 500 g

recuadro ancho 10 cm

Por un lado sería torpe almacenar los datos de una manera que otorgue a cada atributo una columna propia,
ya que muchos atributos no son relevantes para un determinado objeto.

Por otro lado, el aspecto sería muy desordenado si se mostraran los datos mezclando longitudes, colores y
pesos.

Si se carga esta base de datos en Qlik Sense empleando el modo estándar y mostramos los datos en una tabla,
esta presenta el siguiente aspecto:

Gestión de datos - Qlik Sense, June 2019 250


8   Mejores prácticas de modelado de datos

Sin embargo, si la tabla se carga como una base de datos genérica, dividirá las columnas dos y tres en tablas
diferentes, una por cada valor único de la segunda columna:

La sintaxis para esto es fácil:

Example:

Generic SELECT* from GenericTable;


No importa si se usa una sentencia LOAD o SELECT para cargar una base de datos genérica.

8.15 Emparejar intervalos con datos discretos


El prefijo intervalmatch delante de una sentencia LOAD o SELECT se utiliza para enlazar valores numéricos
discretos con uno o más intervalos numéricos. Es una característica muy potente que se puede utilizar, por
ejemplo, en entornos de producción, como se muestra en el ejemplo inferior.

Ejemplo de intervalmatch
Observe las dos tablas inferiores. La primera tabla muestra el inicio y el final de la producción de diferentes
pedidos. La segunda tabla contiene algunos eventos discretos. ¿Cómo podemos asociar los eventos discretos
con los pedidos para saber, por ejemplo, qué cambio afecta a qué pedidos y qué pedidos se procesaron a causa
de qué cambios?

Gestión de datos - Qlik Sense, June 2019 251


8   Mejores prácticas de modelado de datos

Tabla OrderLog
Inicio Fin Orden

01:00 03:35 A

02:30 07:58 B

03:04 10:27 C

07:23 11:43 D

Tabla EventLog
Time Evento Comentario

00:00 0 Inicio de shift 1

01:18 1 Fin de línea

02:23 2 Reinicio de línea 50%

04:15 3 Velocidad de línea 100%

08:00 4 Inicio de shift 2

11:43 5 Fin de la producción

Primero, cargue las dos tablas como de costumbre y después vincule el campo Time a los intervalos definidos
por los campos Start y End:

SELECT * from OrderLog;


SELECT * from EventLog;
Intervalmatch (Time) SELECT Start,End from OrderLog;
Ahora puede crear una tabla en Qlik Sense, como se muestra a continuación:

Tabla con el campo Time vinculado a los intervalos definidos por Inicio y Fin
Time Evento Comentario Orden Comienzo End

0:00 0 Inicio de shift 1 - - -

1:18 1 Fin de línea A 1:00 3:35

2:23 2 Reinicio de línea 50% A 1:00 3:35

4:15 3 Velocidad de línea 100% B 2:30 7:58

4:15 3 Velocidad de línea 100% C 3:04 10:....

8:00 4 Inicio de shift 2 C 3:04 10:....

8:00 4 Inicio de shift 2 D 7:23 11:....

11:43 5 Fin de la producción E 7:23 11:.....

Ahora podemos ver fácilmente que el pedido A se vio afectado principalmente por la parada de línea, pero que
la velocidad reducida de la línea de producción también afectó a los pedidos B y C. Solo los pedidos C y D fueron
gestionados en parte por Shift 2.

Gestión de datos - Qlik Sense, June 2019 252


8   Mejores prácticas de modelado de datos

Tenga en cuenta los puntos siguientes cuando use intervalmatch :

l Antes de la sentencia intervalmatch , el campo que contiene los puntos de datos discretos (Time en el
ejemplo superior) ya debe haberse leído en Qlik Sense. La sentencia intervalmatch no lee este campo
desde la tabla de la base de datos.
l La tabla leída en la sentencia intervalmatch LOAD o SELECT siempre debe contener exactamente dos
campos (Start y End en el ejemplo anterior). Para definir un enlace a otros campos, debe leer los campos
de intervalo junto con campos adicionales en una sentencia aparte LOAD o SELECT (la primera
sentencia SELECT en el ejemplo anterior).
l Los intervalos están siempre cerrados. Es decir, los puntos finales se incluyen en el intervalo. Los límites
no numéricos hacen que se descarte el intervalo (no definido) mientras que los límites NULL amplían el
intervalo indefinidamente (ilimitado).
l Los intervalos pueden solaparse y los valores discretos se enlazarán con todos los intervalos
coincidentes.

Utilizar la sintaxis ampliada de intervalmatch para resolver problemas


de cambios de dimensión progresivos
La sintaxis ampliada de intervalmatch puede emplearse para gestionar el conocido problema del cambio de
dimensión progresivo en las fuentes de datos.

Script a modo de ejemplo:


SET NullInterpret='';

IntervalTable:
LOAD Key, ValidFrom, Team
FROM 'lib://dataqv/intervalmatch.xlsx' (ooxml, embedded labels, table is IntervalTable);

Key:
LOAD
Key,
ValidFrom as FirstDate,
date(if(Key=previous(Key),
previous(ValidFrom) - 1)) as LastDate,
Team
RESIDENT IntervalTable order by Key, ValidFrom desc;

drop table IntervalTable;

Transact:
LOAD Key, Name, Date, Sales
FROM 'lib://dataqv/intervalmatch.xlsx' (ooxml, embedded labels, table is Transact);

INNER JOIN intervalmatch (Date,Key) LOAD FirstDate, LastDate, Key RESIDENT Key;
La sentencia nullinterpret solo es necesaria cuando se leen datos desde un archivo de tabla, ya que los valores
inexistentes se definen como cadenas vacías, en lugar de valores NULL.

Cargar los datos desde IntervalTable dará como resultado la siguiente tabla:

Gestión de datos - Qlik Sense, June 2019 253


8   Mejores prácticas de modelado de datos

Table with data loaded from IntervalTable


Key FirstDate Team

000110 2011-01-21 Southwest

000110 - Northwest

000120 - Northwest

000120 2013-03-05 Southwest

000120 2013-03-05 Northwest

000120 2013-03-05 Southwest

La sentencia nullasvalue permite que los valores NULL se enlacen con los valores de la lista.

Crear Key, FirstDate, LastDate (campos de atributo) empleando previous y order by y por lo tanto
IntervalTable se elimina, siendo reemplazado por esta tabla clave.

Cargar los datos desde Transact dará como resultado la siguiente tabla:

Tabla con datos cargados desde Transact


Clave Nombre Fecha Ventas

000110 Spengler Aaron 2009-08-18 100

000110 Spengler Aaron 2009-12-25 200

000110 Spengler Aaron 2011-02-03 300

000110 Spengler Aaron 2011-05-05 400

000120 Ballard John 2011-06-04 500

000120 Ballard John 2013-01-20 600

000120 Ballard John 2013-03-10 700

000120 Ballard John 2013-03-13 800

000120 Ballard John 2013-09-21 900

La sentencia intervalmatch precedida por inner join remplaza la clave de arriba por una clave sintética que
conecta con la tabla Transact, dando como resultado la tabla siguiente:

Tabla con la sentencia intervalmatch precedida por inner join


Clave Equipo Nombre FirstDate LastDate Date Ventas

000110 Northwest Spengler Aaron - 2011-01-20 2009-08-18 100

000110 Northwest Spengler Aaron - 2011-01-20 2009-12-25 200

000110 Southwest Spengler Aaron 2011-01-21 2011-02-03 300

000110 Southwest Spengler Aaron 2011-01-21 2011-05-05 400

Gestión de datos - Qlik Sense, June 2019 254


8   Mejores prácticas de modelado de datos

Clave Equipo Nombre FirstDate LastDate Date Ventas

000120 Northwest Ballard John 2013-01-05 2011-06-04 500

000120 Southwest Ballard John 2013-01-06 2013-03-04 2013-01-20 600

000120 Southwest Ballard John 2013-03-05 2013-03-10 700

000120 Southwest Ballard John 2013-03-05 2013-03-13 800

000120 Southwest Ballard John 2013-03-05 2013-09-21 900

8.16 Creación de un intervalo de fechas a partir de una sola


fecha
En ocasiones, los intervalos de tiempo no se almacenan de forma explícita con un principio y un final. En su
lugar, están implícitos solo por un campo: la indicación de fecha-hora del cambio.

Podría ser como sucede en la tabla a continuación, en la que hay tipos de cambio para múltiples divisas: Cada
cambio de tipo de divisa está en su propia fila, cada una de ellas con una nueva tasa de conversión. Asimismo,
la tabla contiene filas con fechas vacías que corresponden a la tasa de conversión inicial, antes de que se hiciera
el primer cambio.

Tipos de cambio
Moneda Fecha de cambio Tasa

EUR - 8,59

EUR 28/01/2013 8,69

EUR 15/02/2013 8.45

USD - 6.50

USD 10/01/2013 6.56

USD 03/02/2013 6.30

La tabla anterior define un conjunto de intervalos que no se superponen, donde los datos de inicio se llaman
“ Change Date” y la fecha de finalización se define por el comienzo del siguiente intervalo. Pero, ya que la fecha
de finalización no se almacena de forma explícita en su propia columna, necesitamos crear esta columna para
que la nueva tabla se convierta en una lista de intervalos.

Haga lo siguiente:

1. Cree una nueva app y asígnele un nombre.


2. Agregue una nueva sección de script en el Editor de carga de datos.
3. Agregue la siguiente tabla inline. Asegúrese de que las fechas en la columna Change Date estén en el
mismo formato que el formato de fecha local.
In_Rates:
LOAD * Inline [

Gestión de datos - Qlik Sense, June 2019 255


8   Mejores prácticas de modelado de datos

Currency,Change Date,Rate
EUR,,8.59
EUR,28/01/2013,8.69
EUR,15/02/2013,8.45
USD,,6.50
USD,10/01/2013,6.56
USD,03/02/2013,6.30
];

4. Determine con qué rango de fechas desea trabajar. El inicio del rango debe ser anterior a la primera
fecha de los datos, y el final del rango debe ser posterior a la última.
Agregue lo siguiente a la parte superior de su script:
Let vBeginTime = Num('1/1/2013');
Let vEndTime = Num('1/3/2013');
Let vEpsilon = Pow(2,-27);

5. Cargue los datos de origen, pero cambie las fechas vacías en el principio del rango definido en el punto
anterior. La fecha de cambio debe cargarse como From Date.
Ordene la tabla primero por Currency, después conforme a From Date descendente, de modo que tenga
las fechas más recientes en la parte superior.
Agregue lo siguiente tras la tabla In_Rates:
Tmp_Rates:
LOAD Currency, Rate,
Date(If(IsNum([Change Date]), [Change Date], $(#vBeginTime))) as FromDate
Resident In_Rates;

6. Ejecute un segundo pase a través de los datos donde se calcule el To Date. Si el registro actual tiene una
moneda (currency) diferente del registro anterior, entonces es el primer registro de una nueva moneda
(pero su último intervalo), por lo que deberá usar el final del rango definido en el paso 1. Si es la misma
moneda (currency), debe tomar el From Date del registro anterior, restar una pequeña cantidad de
tiempo y usar este valor como To Date en el registro actual.
Agregue lo siguiente tras la tabla Tmp_Rates:
Rates:
LOAD Currency, Rate, FromDate,
Date(If( Currency=Peek('Currency'),
Peek('FromDate') - $(#vEpsilon),
$(#vEndTime)
)) as ToDate
Resident Tmp_Rates
Order By Currency, FromDate Desc;

Drop Table Tmp_Rates;

Su script debería tener el aspecto siguiente:

Let vBeginTime = Num('1/1/2013');


Let vEndTime = Num('1/3/2013');
Let vEpsilon = Pow(2,-27);

In_Rates:
LOAD * Inline [
Currency,Change Date,Rate
EUR,,8.59
EUR,28/01/2013,8.69
EUR,15/02/2013,8.45

Gestión de datos - Qlik Sense, June 2019 256


8   Mejores prácticas de modelado de datos

USD,,6.50
USD,10/01/2013,6.56
USD,03/02/2013,6.30
];  

Tmp_Rates:
LOAD Currency, Rate,
Date(If(IsNum([Change Date]), [Change Date], $(#vBeginTime))) as FromDate
Resident In_Rates; 

Rates:
LOAD Currency, Rate, FromDate,
Date(If( Currency=Peek('Currency'),
Peek('FromDate') - $(#vEpsilon),
$(#vEndTime)
)) as ToDate
Resident Tmp_Rates
Order By Currency, FromDate Desc; 

Drop Table Tmp_Rates;

El script actualizará la tabla de origen de la siguiente forma:

Tabla fuente actualizada


Moneda Rate FromDate ToDate

EUR 8.45 15/02/2013 vEndTime

EUR 8.69 28/01/2013 14/02/2013 23:59:59

EUR 8.59 vBeginTime 28/01/2013 23:59:99

USD 6.30 03/02/2013 vEndTime

USD 6.56 10/01/2013 2/02/2013 23:59:59

USD 6.50 vBeginTime 9/01/2013 23:59:59

En su app, la tabla presentará el siguiente aspecto:

Vista previa de datos


Moneda Rate FromDate ToDate

EUR 8,45 15/02/2013 01/03/2013

EUR 8,69 28/01/2013 14/02/2013

EUR 8,59 01/01/2013 28/01/2013

USD 6.30 03/02/2013 01/03/2013

USD 6.56 10/01/2013 2/02/2013

USD 6.50 01/01/2013 9/01/2013

Gestión de datos - Qlik Sense, June 2019 257


8   Mejores prácticas de modelado de datos

Esta tabla se puede usar posteriormente en una comparativa en una determinada fecha usando el método
Intervalmatch.

8.17 Cargar datos jerárquicos


Las jerarquías de n niveles desequilibrados se utilizan a menudo para representar dimensiones geográficas u
organizativas en los datos, entre otras cosas. Estos tipos de jerarquías se almacenan normalmente en una tabla
de nodos adyacentes, que es una tabla en la que cada registro corresponde a un nodo y tiene un campo que
contiene una referencia al nodo padre.

Tabla Nodos
IDNodo IDParentNode Título

1 - Director General

2 1 Director Regional

3 2 Director de Oficina

4 3 Director de Departamento

En este tipo de tabla, el nodo se almacena en un único registro, pero puede tener cualquier número de hijos. La
tabla puede por supuesto contener campos adicionales que describan atributos para los nodos.

Una tabla de nodos adyacentes es óptima para el mantenimiento, pero difícil de utilizar en el trabajo diario. En
las consultas y el análisis se suelen emplear otras representaciones en vez. La tabla de nodos expandidos es una
representación habitual, en la que cada nivel de la jerarquía se almacena en un campo aparte. Los niveles en
una tabla de nodos expandidos se pueden usar fácilmente, por ej. en una estructura de árbol. La palabra clave
hierarchy se puede usar en el script de carga de datos para transformar una tabla de nodos adyacentes en una
tabla de nodos expandidos.

Example:

Hierarchy (NodeID, ParentNodeID, Title, 'Manager') LOAD


NodeID,
ParentNodeID,
Title
FROM 'lib://data/hierarchy.txt' (txt, codepage is 1252, embedded labels, delimiter is ',', msq);
Tabla de nodos expandidos
IDNodo IDParentNode Título Title1 Title2 Title4 Title4

1 - Director General Director - - -


General

2 1 Director Regional Director Director - -


General Regional

3 2 Director de Director Director Director de -


Oficina General Regional Oficina

4 3 Director de Director Director Director de Director de


Departamento General Regional Oficina Departamento

Gestión de datos - Qlik Sense, June 2019 258


8   Mejores prácticas de modelado de datos

Un inconveniente de la tabla de nodos expandidos es que no es fácil utilizar los campos de nivel para búsquedas
o selecciones, dado que se necesita un conocimiento previo acerca de qué nivel explorar o seleccionar. Una
tabla de antepasados supone una representación diferente que resuelve este problema. Esta representación
también se conoce con el nombre de tabla puente.

Una tabla de antepasados contiene un registro por cada relación hijo-antepasado que encuentra en los datos.
Contiene claves y nombres de los hijos y antepasados. Es decir, cada registro describe a qué nodo pertenece un
nodo específico. La palabra clave hierarchybelongsto se puede usar en el script de carga de datos para
transformar una tabla de nodos adyacentes en una tabla de ancestros.

8.18 Cargar sus propios datos de mapa


Para poder crear una visualización de mapa, necesita tener acceso a datos geográficos que se conecten a los
datos de su app. Qlik Sense puede usar:

l Datos de nombres en los campos para colocar ubicaciones en las capas del mapa.
l Campos que contienen geopuntos (latitud y longitud) en WGS-84.
l Campos que contienen geopuntos, polígonos o líneas de una fuente de datos geográficos, por ejemplo
un archivo KML.
l Campos que contienen geodatos en GeoJSON, LineString o formatos MultiLineString.
l Campos que contienen coordenadas no WGS-84 (cuando se usa un mapa personalizado como mapa
base).

Al cargar datos de mapas en el Gestor de datos con los perfiles de datos habilitados, el servicio de perfilado de
datos identificará nombres de países, nombres de ciudades y campos de latitud y longitud y cargará las
geometrías correspondientes en nuevos campos. En el Editor de carga de datos, puede, de manera opcional,
combinar campos de coordenadas en un solo campo para su comodidad.

Datos de nombre admitidos para campos en una visualización de mapa


La visualización del mapa puede usar datos de nombres en los campos para colocar ubicaciones en las capas
del mapa. Se pueden utilizar los siguientes tipos de ubicación: 

l Nombres de continentes
l Nombres de países
l Códigos de país ISO alfa 2
l Códigos de país ISO alfa 3
l Nombres de divisiones administrativas de primer nivel, como el nombre de un estado o provincia
l Nombres de divisiones administrativas de segundo nivel
l Nombres de divisiones administrativas de tercer nivel
l Nombres de divisiones administrativas de cuarto nivel
l Nombres de ciudades, pueblos u otras poblaciones
l Códigos postales
l Códigos de aeropuerto IATA
l Códigos de aeropuerto OACI

Gestión de datos - Qlik Sense, June 2019 259


8   Mejores prácticas de modelado de datos

La disponibilidad de lugares puede variar según el país. Si la ubicación mencionada no está


disponible, use datos de coordenadas o área para la ubicación.

Qlik Sense utiliza el mapa y los datos de ubicación obtenidos de reconocidos líderes del sector que
utilizan metodologías aceptadas y las mejores prácticas para marcar fronteras y nombrar países
dentro de sus asignaciones. Qlik Sense proporciona flexibilidad para permitir a los usuarios integrar
sus propios mapas de fondo. Si los mapas estándar no se ajustan, Qlik Sense ofrece la opción de
cargar mapas de fondo, bordes y áreas proporcionados por el cliente.

Cargar datos de área y puntos desde un archivo KML


Puede añadir datos desde un archivo KML a su mapa en el Gestor de datos y el Editor de carga de datos. De
forma predeterminada, todos los archivos se muestran seleccionados en el cuadro de diálogo de selección de
datos, aunque no contengan datos. Un KML podría contener, por ejemplo, datos de área pero no datos de
puntos. Al agregar datos de un archivo KML que contiene un punto o campo de área vacío en Qlik Sense, puede
excluir el campo vacío sin correr el riesgo de crear dimensiones de mapa sin ningún tipo de datos.

Al agregar un campo de un campo KML a una capa de mapa, si el campo de nombre contiene datos de nombre
significativos, debe agregarse como la dimensión de la capa. El área o el campo de puntos se deben agregar
entonces como Campo de localización . No habrá diferencia en cómo se visualizan los datos en la capa, y el
texto en el campo de nombre se mostrará como información sobre herramientas.

Si el archivo KML no contiene datos de puntos, datos de línea o datos de área, no puede cargar
datos de ese archivo. Si el archivo KML file is corrupt, an error message is displayed, and you will not
be able to load the data.

Cargar datos de mapa con perfilado de datos


Cuando cargue datos geográficos utilizando Añadir datos en el Gestor de datos con el perfil de datos
habilitado, Qlik Sense tratará de reconocer si sus datos contienen: 

l Nombres de países y ciudades a partir de sus datos.


l Datos de geopuntos (latitud, longitud) para una única ubicación, como una ciudad.
l Datos de área (polígonos de geopuntos) para representar regiones o países.

Si los encuentra, se creará automáticamente un nuevo campo que contiene información geográfica.

Cuando utilice Añadir datos, el perfilado de datos debe estar habilitado. Esta es la opción por
defecto. Si deshabilita la generación de perfiles de datos, los datos geográficos no se detectan y no
se crea el nuevo campo con datos geográficos.

Gestión de datos - Qlik Sense, June 2019 260


8   Mejores prácticas de modelado de datos

Si se reconocieron ciudades durante la preparación de datos, el nuevo campo contiene geopuntos, y si se


reconocieron países el nuevo campo contiene datos de polígonos de área. Este campo se denomina <data
field>_GeoInfo. Por ejemplo, si los datos contienen un campo denominado Office que contiene nombres de
ciudades, se crea un campo con geopuntos denominado Office_GeoInfo.

Qlik Sense analiza un subconjunto de datos para reconocer los campos que contienen ciudades o
países. Si el resultado es menor del 75 por ciento, no se creará un campo con información
geográfica. Si un campo no se reconoce como datos geográficos, puede cambiar manualmente el
tipo de campo a datos geográficos.

Para más información, vea Cambiar los tipos de campos (page 70).

Los campos con información geográfica no muestran los geopuntos o datos de polígonos en el panel de vista
previa de Asociaciones ni en la vista de Tablas. En su lugar, los datos se indican de forma genérica como [GEO
DATOS]. Esto mejora la velocidad con la que se muestran las vistas de Asociaciones y Tablas. Los datos están
disponibles, no obstante, cuando crea visualizaciones en la vista de Hoja.

Cargar y dar formato a datos de puntos


Puede crear un mapa usando datos de puntos (coordenadas). Se admiten dos formatos:

l Los datos de puntos se almacenan en dos campos, uno para la latitud y otro para la longitud. Puede
agregar los campos a una capa de puntos en los campos de latitud y longitud en la capa de puntos.
Opcionalmente, puede combinarlos en un solo campo. Para combinarlos en un solo campo:
l Si utilizó Añadir datos con el perfilado de datos habilitado para cargar la tabla, se reconocen
los campos de latitud y longitud y se crea automáticamente un campo de geopunto.
l Si cargó los datos utilizando el script de carga de datos, puede crear un solo campo con datos de
puntos en el formato [x, y], usando la función GeoMakePoint().
Para más información, vea Ejemplo: Cargar datos de puntos de diferentes columnas de latitud y
longitud con el script de carga de datos (page 261).
l Los datos de puntos se almacenan en un campo. Cada punto se especifica como una matriz de
coordenadas x e y: [x, y]. Con coordenadas geoespaciales, esto correspondería a [longitud, latitud].
Cuando utilice este formato y cargue los datos en el Editor de carga de datos, se recomienda etiquetar
el campo de datos de puntos con $geopoint;.
Para más información: Ejemplo: Cargar datos de puntos desde una única columna con el script de carga
de datos (page 262).

En los ejemplos siguientes damos por sentado que los campos contienen los mismos datos sobre la ubicación de
las oficinas de una empresa, pero en dos formatos distintos.

Ejemplo: Cargar datos de puntos de diferentes columnas de latitud y longitud con el script


de carga de datos
El archivo Excel incluye el contenido siguiente para cada oficina:

Gestión de datos - Qlik Sense, June 2019 261


8   Mejores prácticas de modelado de datos

l Oficina (Office)
l Latitud (Latitude)
l Longitud (Longitude)
l Número de empleados (Employees)

El script de carga podría quedar de la siguiente manera:

LOAD
Office,
Latitude,
Longitude,
Employees
FROM 'lib://Maps/Offices.xls'
(biff, embedded labels, table is (Sheet1$));

Combine los datos de los campos Latitude y Longitude para definir un nuevo campo para los puntos.

Ejecute el script y cree una visualización de mapa. Añada la dimensión a su mapa.

Puede elegir crear la dimensión Location en el script agregando la siguiente cadena encima del comando
LOAD:

LOAD *, GeoMakePoint(Latitude, Longitude) as Location;

La función GeoMakePoint() une los datos de longitud y latitud.

Se recomienda etiquetar el campo Office con $geoname para que se reconozca como el nombre de un
geopunto. Agregue las siguientes líneas después de la última cadena en el comando LOAD:

TAG FIELDS Office WITH $geoname;


El script completo queda de la siguiente manera:

LOAD *, GeoMakePoint(Latitude, Longitude) as Location;


LOAD
Office,
Latitude,
Longitude,
Employees
FROM 'lib://Maps/Offices.xls'
(biff, embedded labels, table is (Sheet1$));

TAG FIELDS Office WITH $geoname;


Ejecute el script y cree una visualización de mapa. Añada la dimensión a su mapa.

Ejemplo: Cargar datos de puntos desde una única columna con el script de carga de datos
El archivo Excel incluye el contenido siguiente para cada oficina:

l Oficina (Office)
l Localización (Location)
l Número de empleados (Employees)

El script de carga podría quedar de la siguiente manera:

LOAD

Gestión de datos - Qlik Sense, June 2019 262


8   Mejores prácticas de modelado de datos

Office,
Location,
Employees
FROM 'lib://Maps/Offices.xls'
(biff, embedded labels, table is (Sheet1$));

El campo Location contiene los datos de puntos y se recomienda etiquetar el campo con $geopoint para que se
reconozca como un campo de datos de puntos. Se recomienda etiquetar el campo Office con $geoname para
que se reconozca como el nombre de un geopunto. Agregue las siguientes líneas después de la última cadena en
el comando LOAD:

TAG FIELDS Location WITH $geopoint;


TAG FIELDS Office WITH $geoname;
El script completo queda de la siguiente manera:

LOAD
Office,
Location,
Employees
FROM 'lib://Maps/Offices.xls'
(biff, embedded labels, table is (Sheet1$));
TAG FIELDS Location WITH $geopoint;
TAG FIELDS Office WITH $geoname;

Ejecute el script y cree una visualización de mapa. Añada la dimensión a su mapa.

8.19 Limpieza de datos


Cuando cargamos datos de diferentes tablas, observamos que los nombres de los valores de campos no han
sido asignados siempre de forma consistente. Esta falta de consistencia, aparte de ser molesta, impide también
las asociaciones, es decir, que se hace imprescindible resolver el problema. La forma elegante de solucionar esto
es creando una tabla de correspondencias que compare los valores de campo.

Tablas de correspondencia
Las tablas cargadas por medio de mapping load o mapping select se tratan de manera diferente a otras
tablas. Se almacenan en un área aparte de la memoria, y se usan solo como tablas de correspondencia durante
la ejecución del script. Después de la ejecución del script se borran automáticamente.

Reglas:
l Una tabla de correspondencia debe tener dos columnas, la primera con los valores de la comparación y
la segunda con los valores que se desea enlazar.
l Las dos columnas deben tener nombre, pero los nombres no tienen importancia por sí mismos. Los
nombres de las columnas no tienen conexión con los nombres de campo en las tablas internas regulares.

Utilizar una tabla de correspondencia


Cuando se cargan varias tablas con listas de países, ocurre a veces que se encuentra el mismo país con nombres
diferentes. En este ejemplo, U.S.A. aparece listado en US, U.S. y United States.

Gestión de datos - Qlik Sense, June 2019 263


8   Mejores prácticas de modelado de datos

Para evitar la aparición de tres registros diferentes que denotan el mismo país de los Estados Unidos de América
en la tabla concatenada, se puede crear una tabla parecida a la ya mostrada y cargarla como tabla de
correspondencia (o enlace).

El script completo presentará el siguiente aspecto:

CountryMap:
Mapping LOAD x,y from MappingTable.txt
(ansi, txt, delimiter is ',', embedded
labels);
Map Country using CountryMap;
LOAD Country,City from CountryA.txt
(ansi, txt, delimiter is ',', embedded labels);
LOAD Country, City from CountryB.txt
(ansi, txt, delimiter is ',', embedded labels);
La sentencia mapping carga el archivo MappingTable.txt como una tabla de correspondencia con la etiqueta
CountryMap.

La sentencia map habilita la asignación del campo Country usando la tabla de correspondencia cargada
previamente.CountryMap.

La sentencias LOAD cargan las tablas CountryA y CountryB. Estas tablas, que se concatenarán debido a que
tienen el mismo conjunto de campos, incluyen el campo Country, cuyos valores de campo se compararán con
los de la primera columna de la tabla de correspondencia. Los valores de campo US, U.S. y United States serán
encontrados y reemplazados por los valores de la segunda columna de la tabla de correspondencia, es decir,
USA .

La correspondencia automática es el último paso en la cadena de eventos que lleva al campo que se está
almacenando en la tabla de Qlik Sense. Por lo general, el orden de eventos de una típica sentencia LOAD o
SELECT es el siguiente:

1. Evaluación de las expresiones


2. Renombrado de campos mediante as
3. Renombrado de campos mediante alias
4. Calificación del nombre de tabla, si procede
5. Enlazar datos en nombres de campo que coinciden

Esto significa que la correspondencia no se hace cada vez que se encuentra un nombre de campo como parte
de una expresión, sino más bien cuando el valor se almacena con el nombre de un campo de la tabla de Qlik
Sense.

Para deshabilitar la correspondencia use la sentencia unmap.

Para mapear a nivel de expresión, use la función applymap.

Para mapear a un nivel de subcarpeta, use la función mapsubstring.

Gestión de datos - Qlik Sense, June 2019 264


9   Resolución de problemas - Cargar datos

9 Resolución de problemas - Cargar datos


Esta sección describe problemas que se pueden presentar durante la carga y modelado de datos en Qlik Sense.

9.1 Una conexión de datos deja de funcionar después


de reiniciar SQL Server
Possible cause

Si crea una conexión de datos a un SQL Server y después reinicia SQL Server, la conexión de datos puede que
deje de funcionar y no pueda seleccionar datos. Qlik Sense ha perdido la conexión al SQL Server y no ha podido
volver a conectar.

Proposed action

Qlik Sense:

Haga lo siguiente:

l Cierre la app y ábrala de nuevo desde el centro de control.

Qlik Sense Desktop:

Haga lo siguiente:

1. Cierre todas las apps.


2. Reinicie Qlik Sense Desktop.

9.2 Advertencia de claves sintéticas al cargar los


datos
Si ha cargado varios archivos, puede que reciba una advertencia de que se han creado claves sintéticas tras
cargar los datos.

Possible cause

Si dos tablas contienen más de un campo común, Qlik Sense crea una clave sintética para solucionar ese enlace.

Proposed action

En muchos casos no habrá que hacer nada con las claves sintéticas si el enlace funciona bien, pero siempre es
conveniente revisar la estructura de datos en el visor del modelo de datos.

Gestión de datos - Qlik Sense, June 2019 265


9   Resolución de problemas - Cargar datos

9.3 Advertencia de referencias circulares al cargar los


datos
Possible cause

Si ha cargado más de dos tablas, las tablas pueden asociarse de tal manera que haya más de una ruta de
asociaciones entre dos campos, ocasionando un bucle en la estructura de datos.

Proposed action

9.4 Problemas de selección de datos con una fuente


de datos OLE DB
Esta funcionalidad no está disponible en Kubernetes.

Possible cause

Si no puede seleccionar datos de una conexión de datos OLE DB, debe verificar cómo está configurada la
conexión.

Proposed action

Haga lo siguiente:

1. Compruebe que la cadena de conexión esté correctamente diseñada.

2. Compruebe que está utilizando las credenciales adecuadas para acceder.

9.5 Problemas de juego de caracteres con archivos


de datos ANSI no codificados
Puede experimentar problemas con la codificación de caracteres en archivos de datos ANSI no codificados
cuando usa una conexión de datos ODBC.

Possible cause

Las conexiones de datos ODBC no proporcionan capacidades completas para la codificación del juego de
caracteres.

Proposed action

Haga lo siguiente:

l Si es posible, importe los archivos de datos empleando una conexión de datos de carpeta, la cual ofrece
más opciones para el manejo de códigos de caracteres. Esta es probablemente la mejor opción si está

Gestión de datos - Qlik Sense, June 2019 266


9   Resolución de problemas - Cargar datos

cargando una hoja de cálculo de Microsoft Excel o un archivo de datos de texto.

9.6 El conector no funciona


En Qlik Sense Enterprise on Windows, está tratando de crear una conexión de datos a un conector instalado
aparte en el editor de carga de datos, pero la conexión falla, o una conexión se etiqueta como desconocida.

El conector no está bien instalado


Possible cause

El conector no se ha instalado correctamente conforme a las instrucciones de instalación. Si una app utiliza un
conector en un sitio multi nodo, el conector debe instalarse en todos los nodos.

Proposed action

Haga lo siguiente:

l Verifique que el conector esté instalado de conformidad con las instrucciones en todos los nodos del sitio.

El conector no está adaptado para Qlik Sense


Possible cause

Los conectores QlikView necesitan adaptarse a Qlik Sense si desea poder seleccionar datos.

Proposed action (si desarrolló el conector usted mismo con el QVX SDK)

Haga lo siguiente:

l Necesita adaptar el conector para Qlik Sense con una interfaz para seleccionar los datos.

Proposed action (si el conector se le ha suministrado)

Haga lo siguiente:

l Contacte con el proveedor del conector para adquirir un conector adaptado a Qlik Sense.

9.7 El script de carga de datos se ejecuta sin errores,


pero los datos no se cargan
El script se ejecuta sin errores de carga ni de sintaxis, pero los datos no se cargan conforme a lo esperado. Una
recomendación general es activar la depuración para avanzar por el script y examinar los resultados de la
ejecución, pero aquí tiene algunas causas habituales de error.

Una sentencia no termina en punto y coma


Possible cause

Ha olvidado terminar una sentencia con un punto y coma.

Proposed action

Haga lo siguiente:

Gestión de datos - Qlik Sense, June 2019 267


9   Resolución de problemas - Cargar datos

l Termine todas las sentencias con un punto y coma.

Usar comillas simples en una cadena


Possible cause

Una cadena contiene un único carácter de comilla en, por ejemplo, una sentencia de una variable SET.

Proposed action

Haga lo siguiente:

l Si una cadena contiene un único carácter de comilla, necesita terminar con otro carácter único de
comilla.

9.8 Las columnas no se alinean según lo esperado al


seleccionar datos de un archivo de registro fijo
Possible cause

El archivo utiliza tabuladores entre columnas. Normalmente verá que las cabeceras de campo no se alinean con
los datos esperados si selecciona Saltos de campo en el diálogo de selección.

En este caso, el tabulador equivale a una serie de caracteres.

Proposed action

Haga lo siguiente:

1. Seleccione Sin nombres de campo en Nombres de campo.


2. Seleccione Saltos de campo.
3. Aumente el parámetro Tamaño de pestaña hasta que vea que las columnas se alinean con la
cabecera.
4. Inserte saltos de campo haciendo clic en las posiciones de columna adecuadas.
5. Seleccione Vista previa de datos.
6. Seleccione Nombres de campo incluidos en Nombres de campo.

Las columnas ahora se alinean como es debido y cada campo debe mostrar su nombre de campo correcto.

9.9 Mensaje de error "Ruta no válida" al adjuntar un


archivo
Possible cause

El nombre del archivo es demasiado largo. Qlik Sense solo admite nombres de archivo de hasta 171 caracteres.

Proposed action

Renombre el archivo con un nombre que contenga menos de 172 caracteres.

Gestión de datos - Qlik Sense, June 2019 268


9   Resolución de problemas - Cargar datos

9.10 Errores al cargar una app convertida desde un


documento QlikView
En Qlik Sense Enterprise on Windows, puede que reciba errores al cargar una app que fue convertida desde un
documento de QlikView por diferencias entre ambos productos.

Referencias a rutas relativas utilizadas en el script


Possible cause

El script de carga se refiere a archivos utilizando rutas absolutas, lo cual no se admite en el modo estándar de
Qlik Sense. Ejemplos de mensajes de error son "Invalid Path" y "LOAD statement only works with lib:// paths in
this script mode".

Proposed action

Haga lo siguiente:

l Reemplace todas las referencias a archivos por referencias lib:// a conexiones de datos en Qlik Sense.

Funciones o sentencias no admitidas utilizadas en el script


Possible cause

Si recibe un error de sintaxis al ejecutar el script en el editor de carga de datos, puede que esté relacionado con
el uso de sentencias de script QlikView o funciones no admitidas en Qlik Sense.

Proposed action

Haga lo siguiente:

l Elimine la sentencia no válida o reemplácela por una válida.

9.11 Problemas para conectarse y cargar datos desde


archivos Microsoft Excel a través de ODBC
Possible cause

En Qlik Sense Enterprise on Windows, puede encontrar problemas al configurar una conexión de datos ODBC a
un archivo de Microsoft Excel o al cargar datos desde archivos de Microsoft Excel a través de una conexión de
datos ODBC. Esto normalmente se debe a problemas con la configuración de ODBCDSN en Windows o
problemas con los drivers ODBC asociados.

Proposed action

Qlik Sense tiene soporte nativo para cargar archivos Microsoft Excel. Si es posible, reemplace la conexión de
datos ODBC por una conexión de datos de carpeta que conecte con la carpeta que contiene los archivos de
Microsoft Excel.

Gestión de datos - Qlik Sense, June 2019 269


9   Resolución de problemas - Cargar datos

9.12 Adjuntar un archivo soltándolo en Añadir datos


no funciona
Está tratando de adjuntar un archivo arrastrándolo desde el Explorador de Windows y soltándolo en el
diálogo Añadir datos/ Ajuntar archivos de Qlik Sense, pero el archivo no se carga.

Esta funcionalidad no está disponible en Kubernetes.

Possible cause

El archivo se almacena en un archivo ZIP. No es posible adjuntar archivos individuales desde un archivo ZIP en
Qlik Sense, aunque el archivo aparezca como una carpeta en el Explorador de Windows.

Proposed action

Extraiga los archivos del archivo ZIP antes de adjuntarlos.

9.13 Las tablas con campos comunes no se asocian


automáticamente por nombre de campo
Ha añadido dos o más tablas usando Añadir datos. Las tablas tienen campos con un nombre común, pero no
se asocian de forma automática.

Possible cause

Cuando agregó las tablas, mantuvo la opción predeterminada de habilitar el perfilado de datos en el cuadro de
diálogo Añadir datos. Esta opción califica automáticamente todos los nombres de campo que son comunes
entre tablas. Por ejemplo, si añade la tabla A y la tabla B con un campo común F1 usando esta opción, el campo
se denominará F1 en la tabla A y B.F1 en la tabla B. Esto significa que las tablas no se asocian automáticamente.

Proposed action

Abra el Gestor de datos y seleccione la vista Asociaciones. Ahora puede asociar las tablas basándose en las
recomendaciones de perfilado de datos.

Cuando haya asociado las tablas, haga clic en Cargar datos.

9.14 Los campos de fecha no se reconocen como


campos de fecha en la vista de hoja
Tiene campos que contienen datos de fecha y hora, pero no se reconocen como campos de fecha en la vista de
hoja, es decir, no se indican mediante G en el panel de activos y otras listas de campos.

Gestión de datos - Qlik Sense, June 2019 270


9   Resolución de problemas - Cargar datos

El perfilado de datos se deshabilitó al añadirse la tabla


Possible cause

Cuando agregó las tablas, deshabilitó la creación de perfiles de datos en ¥ junto al botón Añadir datos.

Con esta opción, los campos de fecha y fecha-hora que se reconozcan funcionarán correctamente, pero no se
indican mediante G en el panel de activos y otras listas de campos, y los campos de propiedades expandidos
no están disponibles.

Proposed action

Abra el Gestor de datos y haga clic en Cargar datos.

Ahora, todos los campos de fecha y fecha-hora deben indicarse mediante G en el panel de activos de la vista
de hoja. Si todavía no se indican mediante G , los datos de campo probablemente están utilizando un formato
que no se reconoce como una fecha.

El formato de fecha no se reconoce


Possible cause

El formato de entrada del campo de fecha no se ha reconocido al cargar la tabla. Normalmente Qlik Sense
reconoce los campos de fecha automáticamente, basándose en las configuraciones locales y los formatos de
fecha habituales, pero en algunas ocasiones puede que tengamos que especificar el formato de entrada.

Proposed action

Abra el Gestor de datos y edite la tabla que contiene el campo que no se reconoció como una fecha. El campo
probablemente se indique con ⏪ como un campo general. Cambie el tipo de campo a Fecha o Fecha-hora,
con un formato de entrada que coincida con los datos de campo.

9.15 El gestor de datos no muestra las tablas de la app


que contienen datos
Al abrir una app creada en una versión de Qlik Sense anterior a la 3.0, el gestor de datos no muestra las tablas y
aparece un mensaje indicando que la aplicación no contiene datos.

Possible cause

El modelo de datos mejorado en Qlik Sense 3.0 y posteriores requiere una carga de datos para completar la
descripción y preparación de datos.

Proposed action

Haga clic en Cargar datos en el gestor de datos. Esto requiere que la app puede acceder a las fuentes de datos
que se utilizan en la app.

Gestión de datos - Qlik Sense, June 2019 271


9   Resolución de problemas - Cargar datos

9.16 Los flujos de trabajo del gestor de datos se han


roto para todos los usuarios que crean apps en
un servidor
En Qlik Sense Enterprise on Windows, los usuarios obtienen errores cuando tratan de usar Añadir datos o
Cargar datos en el Gestor de datos, o cuando actualizan la app en el navegador.

Possible cause

El Gestor de datos utiliza archivos QVD para almacenar en caché los datos cargados. Estos archivos se
eliminan automáticamente cuando ya no se usan, pero si se acumulan en gran número o si se corrompen,
pueden ocasionar errores.

Proposed action

Elimine la carpeta que contiene los archivos QVD. En un servidor Qlik Sense, la caché se encuentra en:

<Qlik Sense shared folder>\Apps\DataPrepAppCache

En un Qlik Sense Desktop, la caché se encuentra en:

C:\Users\<username>\Documents\Qlik\Sense\Apps\DataPrepAppCache

9.17 Quedarse sin espacio en memoria


En Qlik Sense Enterprise on Windows, hay varias razones por las que un sistema puede tener poca capacidad de
disco, y el método del gestor de datos para almacenar datos cargados en archivos QVD es una posible causa.

Proposed action

Elimine la carpeta que contiene los archivos QVD. En un servidor Qlik Sense, la caché se encuentra en:

<Qlik Sense shared folder>\Apps\DataPrepAppCache

En un Qlik Sense Desktop, la caché se encuentra en:

C:\Users\<username>\Documents\Qlik\Sense\Apps\DataPrepAppCache

9.18 El editor de carga de datos no muestra el script


Cuando se abre el editor de carga de datos, el contenido del editor está en blanco y el script no se puede editar.

Possible cause

El script contiene construcciones muy complejas, por ejemplo, una gran cantidad de sentencias if anidadas.

Gestión de datos - Qlik Sense, June 2019 272


9   Resolución de problemas - Cargar datos

Proposed action

Abra el editor de carga de datos en modo seguro añadiendo /debug/dle_safe_mode a la URL. Esto desactivará
el resaltado de sintaxis y las funciones de autocompletar, pero debería poder editar y guardar el script.

Considere mover las partes complejas de la secuencia de script a un archivo de texto aparte, y
utilice la variable include para insertarla en el script en tiempo de ejecución.

Gestión de datos - Qlik Sense, June 2019 273

También podría gustarte