29 June 2022 How to use the Lookup() function in Qlik Sense 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 about the Lookup() function in Qlik: The correct answer is C: Roller, UMW, Cobretti, Grotti Most of you got 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 many, 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: 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? Want more? Then click the button below for our full archive! More Qlik test prep questions and answers Friday Qlik Test Prep Functions Solution How can we help? Feel free to contact us if you have any comments or questions. Call us Mail us 16 March 2023 Qlik Sense Set Analysis with the P() and E() functions Learn how to answer questions like “What are our total sales for customer who’s purchases included X” by using implicit field selections with the p() and e() functions in Qlik Sense. Friday Qlik Test Prep Set Analysis Solution 9 March 2023 Column references in Qlik Sense This post demonstrates how column references in Qlik Sense work, and what considerations you should make regarding performance. Expressions Friday Qlik Test Prep Solution 7 March 2023 Visualizing a streak in Qlik Sense In this post you’ll learn how to visualize a streak in Qlik Sense based on a practical example with step by step instructyions. Functions Qlik
16 March 2023 Qlik Sense Set Analysis with the P() and E() functions Learn how to answer questions like “What are our total sales for customer who’s purchases included X” by using implicit field selections with the p() and e() functions in Qlik Sense. Friday Qlik Test Prep Set Analysis Solution
9 March 2023 Column references in Qlik Sense This post demonstrates how column references in Qlik Sense work, and what considerations you should make regarding performance. Expressions Friday Qlik Test Prep Solution
7 March 2023 Visualizing a streak in Qlik Sense In this post you’ll learn how to visualize a streak in Qlik Sense based on a practical example with step by step instructyions. Functions Qlik