Ir para conteúdo principal Pular para conteúdo complementar

Usando o mapeamento como uma alternativa à junção

O prefixo Join no Qlik Sense é uma ótima maneira de combinar várias tabelas de dados no modelo de dados.

Uma desvantagem é que as tabelas combinadas podem se tornar grandes e criar problemas de desempenho. Uma alternativa ao Join, nas situações em que você precisa analisar um único valor de outra tabela, é usar o mapeamento. Isso pode prevenir o carregamento de dados desnecessários, que atrasa os cálculos e pode criar erros de cálculo, porque as junções podem mudar o número de registros nas tabelas.

A tabela de mapeamento consiste em duas colunas: um campo de comparação (entrada) e um campo de valor de mapeamento (saída).

Nesse exemplo, temos uma tabela de pedidos (Orders) e precisamos saber quais são os países dos clientes, que estão armazenados na tabela de clientes (Customers).

Tabela de dados Orders
OrderIDOrderDateShipperIDFreteCustomerID
129872007-12-011273
129882007-12-011654
129892007-12-022322
129902007-12-031763
Tabela de dados Customers
CustomerIDNomePaís...
1DataSalesEspanha...
2BusinessCorpItália...
3TechCoAlemanha...
4MobechoFrança...

A fim de procurar o país (Country) de um cliente, precisamos de uma tabela de mapeamento que teria a seguinte aparência:

Tabela de mapeamento
CustomerIDPaís
1Espanha
2Itália
3Alemanha
4França

A tabela de mapeamento, que nomeamos para MapCustomerIDtoCountry, é definida no script da seguinte forma:

MapCustomerIDtoCountry: Mapping LOAD CustomerID, Country From Customers ;

O próximo passo é aplicar o mapeamento, utilizando a função ApplyMap ao carregar a tabela de pedidos:

Orders: LOAD *, ApplyMap('MapCustomerIDtoCountry', CustomerID, null()) as Country From Orders ;

O terceiro parâmetro da função ApplyMap é usado para definir o que deve ser retornado quando um valor não for encontrado na tabela de mapeamento, neste caso Null().

A tabela resultante teria a seguinte aparência:

Tabela de resultados
OrderIDOrderDateShipperIDFreteCustomerIDPaís
129872007-12-011273Alemanha
129882007-12-011654França
129892007-12-022322Itália
129902007-12-031763Alemanha

Saiba mais

 

Esta página ajudou?

Se você encontrar algum problema com esta página ou seu conteúdo - um erro de digitação, uma etapa ausente ou um erro técnico - informe-nos como podemos melhorar!