29 June 2022

LOOKUP

Share this message

Every Friday at Bitmetric we’re posting a new Qlik certification practice question to our LinkedIn company page. Last Friday we asked the following Qlik Data Architect certification practice question: 

Geen alternatieve tekst opgegeven voor deze afbeelding

The correct answer is C: Roller, UMW, Cobretti, Grotti

Most of you have gotten this answer right and that is no surprise. Things like vertical lookup, horizontal lookup and maybe even index match must be very familiar topics for most, but why still use Excel when we have Qlik, right?

The lookup() function will evaluate a field from the current or a previously loaded table and find the matching field you enter. Or to put it as the syntax:

lookup(field_name, match_field_name, match_field_value [, table_name])

To evaluate the right answer let’s visualize what lookup() has exactly done in the figure below:

Geen alternatieve tekst opgegeven voor deze afbeelding

The lookup() function is told to find the field value of ‘Manufacturer’ in the target table and match this to the field value of ‘ManufacturerID’ in the target table and ‘ManufacturerID’ in the current table. In the last part of the syntax we determine the target table which in this example is ‘ManufacturerData’. After the match is made it is added to the current table as the column ‘Manufacturer’. Please notice that all the input which refer to the target table are given in quotes. This is mandatory since the arguments without quotes refer to the current table.

In this example we also immediately notice some of the limitations of lookup(). When Lookup() is being used, it will always return the value based on the load order and if no match is found it will return NULL. So in this example we are missing ManufacturerID = 4, so it returns NULL and since ManufacturerID = 5 is duplicated, it will return Grotti, since that value is loaded first.

And hopefully this is the moment many of you hear the alarm bells ring about data quality. There are quite some things to fix in this data model, we agree, and probably lookup shouldn’t even be used here. Other options like ApplyMap() or even a Join() could just as well be used and are maybe even better, since the performance of lookup() is not known to be the fastest. So why use lookup? The main reason of this example is not to only show the disadvantages of lookup() but also bring us to the advantages. The strength of lookup() doesn’t lie in applying the lookup to whole tables, but more to get single values from a table, for example as use in variables:

LET vExcludeManufacturer =
Lookup('Manufacturer', 'ManufacturerID', 1, 'ManufacturerData');

LET vExcludeManufacturerID =
Lookup('ManufacturerID', 'Manufacturer', 'Roller' , 'ManufacturerData');

These will result in:

vExcludeManufacturer = Roller

vExcludeManufacturerID = 1

And while this is an example in a very small dataset, the use case for large datasets is quite clear.

So to cut it short, while ApplyMap() or Join would be the better and most of the times faster solutions to join fields to another table, Lookup() is a great way to quickly find individual values from a table, for example to use in a variable.

 That’s it for this week. See you next Friday? And remember:

  • If you have suggestions for questions, we love to hear from you via WhatsApp or at info@bitmetric.nl
  • If you’re enjoying these questions and want to work on stuff like this every day (but a bit more challenging), we’re always on the lookout for new colleagues. Check our job openings here.

How can we help?

Feel free to contact us if you have any comments or questions.