_LookupQuery
Last updated 20/12/2024
Overview
This documentation will demonstrate how to use Five's _LookupQuery display type. _LookupQuery enables you to attach a query to a field. The results of this query can be used as the lookup values in the field. In its minimal form a _LookupQuery display type must have:
- A primary key field to have uniqueness
- A value field to display in the lookup
When you select _LookupQuery, a new field will become available called Lookup Data Source. This will require you to select a query that will be used to display the values you want in the field's lookup. The values will be generated from your query.
You can extend your query and provide metadata in a _LookupQuery to return results that can be used in conjunction with a function, or to filter the returned results.
Let's first take a look at an example of a _LookupQuery in its simplest form. In the Soul Food application, a contributor can be added to the application by adding their name.
data:image/s3,"s3://crabby-images/bf465/bf4659daa24dec308ceb35f927a863a80ed92fb1" alt="Contributors form"
When coming to the Recipes form, the person who added the recipe can be selected from the Contributor field, these values are coming from a query that is attached to the field. There is no foreign relationship between the Recipe and Contributor tables, hence, a _LookupQuery can be used to populate the values for the lookup in the Contributor field.
data:image/s3,"s3://crabby-images/ebc93/ebc9310df62e11509a310902ee6a5b48f2ade40e" alt="Contributor field"
Back in Five, the Contributor table has no relationship with any other table in the database. A field has been added to the Recipe table called Contributor.
data:image/s3,"s3://crabby-images/41dee/41deeb04abc74063dae6691db421b359eb75b3b1" alt="Database model"
Form Setup
The Contributors form has been added which references the Contributor table and has the Name field.
data:image/s3,"s3://crabby-images/d2fb9/d2fb91d7a1787024ed8c6d9617a05fc9372ddb92" alt="Contributors form fields"
The Recipes form has a field called Contributor, which is currently just a text field. Effectively, if we were to run the app now, there would be no lookup in the field and only text could be entered into the field.
data:image/s3,"s3://crabby-images/79784/7978440f2548b69f7c50664482de81475ab395f6" alt="Contributor field"
Add a _LookupQuery Display Type
The query for the _LookupQuery needs to be added first and the field we need to edit is the Contributor field on the Recipes form. In the lookup we want the name of each the contributors to be listed.
Add the Query
1. Select Data in the menu.2. Select Queries in the sub-menu.
data:image/s3,"s3://crabby-images/5fb67/5fb674de8022b365fb3273112ddcd3466f395477" alt="Queries menu item"
3. Click the Add Item button.
4. Type an ID in the Data Source ID field.
5. Click in the Query field to open Five's Query Builder.
data:image/s3,"s3://crabby-images/8c55f/8c55ffcc8ff6856b4e9c7503e0f7ccb093626489" alt="Add query"
6. Click the Add Table button.
7. Select a table.
data:image/s3,"s3://crabby-images/d5e5b/d5e5b4b9fa7eb7b3bcfa6546b7b4a7952018d24c" alt="Add Table button"
8. Double click on the table's primary key field and the field with the value you want to display in the lookup.
data:image/s3,"s3://crabby-images/49cee/49ceee4244cddba6e27b80c9195062baecefb2de" alt="Add fields"
9. Click the Save button in the Query Builder app bar.
data:image/s3,"s3://crabby-images/a8c6c/a8c6c2f5872272522708fd1f659117fd861f8dfa" alt="Save button"
10. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/6a8e5/6a8e5b61c4024c92e41c58650b161eb5763dfb75" alt="Save button"
Attach the Query to a Form Field
1. Select Visual in the menu.2. Select Forms in the sub-menu.
data:image/s3,"s3://crabby-images/7c488/7c488e71a4e2ced5e91065908b60064fc7cc179f" alt="Forms menu item"
3. Select the record in the list.
4. Click the Pages tab.
data:image/s3,"s3://crabby-images/b1c30/b1c30a2cca7ad5db3c8d560189091fe3c5db32cd" alt="Pages tab"
5. Select the page record.
data:image/s3,"s3://crabby-images/43c4b/43c4b4a7f9295306fb9d516b41b3dac3bb6d9e06" alt="Page record"
6. Click the Fields tab.
data:image/s3,"s3://crabby-images/2c5b9/2c5b996a952c1143b7cd9962628ac885f31c38df" alt="Fields tab"
7. Select the field record.
data:image/s3,"s3://crabby-images/95cbf/95cbf998964642a59a9146fb1b0cce4ae33a5278" alt="Field record"
8. Either click the Edit button in the form app bar or click directly in the Display Type field.
data:image/s3,"s3://crabby-images/823f5/823f58109cbe2989859c2b0bb52fbee1e4645aff" alt="Edit button"
9. Click the lookup icon in the Display Type field and select _LookupQuery.
10. Click the lookup icon the Lookup Data Source field and select your query.
data:image/s3,"s3://crabby-images/4b3b3/4b3b3f9e65785e9ad3d179eb2dac31fb9cf073a6" alt="Add a _LookupQuery display type"
11. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/2a20c/2a20c2958027ba413f5748113ef227dffb63e343" alt="Save button"
12. Click the Save button in the form app bar above the list.
data:image/s3,"s3://crabby-images/0b578/0b5787d179c87fa792e02df1ee20b07f410aa429" alt="Save button"
Concatenating Fields
Two or more expressions can be concatenated to give the value you want in a lookup. Let's say in the Soul Food application, there are two fields to add a contributor's name, First Name and Last Name.
data:image/s3,"s3://crabby-images/a6975/a697560db97c237aafb3af13b77b0e9be53b2908" alt="Contributors form"
You can add a query that concatenates expressions together to be displayed in a field when using a _LookupQuery display type. Below is an example on how to do this.
SELECT
ContributorKey,
CONCAT(FirstName, ' ', LastName) AS Contributor
FROM
Contributor
With this attached as a _LookupQuery on the Recipe's Contributor field, the full name of the contributor will be available in the lookup.
data:image/s3,"s3://crabby-images/a3896/a3896a8d20b55f7703a60c383d8b1a8669b0ffb3" alt="Contributor field"
_LookupQuery with Metadata
You can add metadata and attach the query to a field with Five's _LookupQuery display type. The metadata is then available on the form and can be available with Five's
Let's take a look at an example. In the Soul Food application, on the Ingredients form there is a Notes field that can be used to add information about the ingredient.
data:image/s3,"s3://crabby-images/cb256/cb256ea646a23a63e552433021faf8509af08904" alt="Ingredients form"
When adding shopping items to a shopping list, if additional notes are added for the selected ingredient, a popup will be displayed holding the information. This is done by the
metadata provided to the Ingredient field and adding a function with Five's
data:image/s3,"s3://crabby-images/cf63f/cf63f60e809bb35a0da97da4bc766e1c6a2b1e61" alt="Popup holding the notes"
Back in Five, the Notes field has been added to the Ingredient table.
data:image/s3,"s3://crabby-images/fb907/fb90779ab501e915a0fba66f5ef254214dff4f79" alt="Database model"
Form Setup
The Notes field has been added to the Ingredients form.
data:image/s3,"s3://crabby-images/8a9d8/8a9d879c37b1db8ec904bb9c1ca5685a015196b7" alt="Notes field"
The Shopping Items form is a list page on the Shopping Lists form.
data:image/s3,"s3://crabby-images/3559f/3559f21351d8e3d0e9dc76bb073152b8931efade" alt="Shopping Lists form pages"
The Ingredient field on the Shopping Items form is currently a lookup and references the Ingredients form. This is the field that will be edited to add a _LookupQuery.
data:image/s3,"s3://crabby-images/e6f5d/e6f5d9dced10a81f60eb2155a1e56d1462dc5c64" alt="Ingredient field"
Add a _LookupQuery with Metadata
A function will use the metadata provided by the query, because of this the following steps need to be performed:
- Add the query
- Add the function
- Attach the _LookupQuery display type
- Attach the function to an event
Add the Query
1. Select Data in the menu.2. Select Queries in the sub-menu.
data:image/s3,"s3://crabby-images/3c5f6/3c5f65899f2835e9ae97e4ad31aee40156e37768" alt="Queries menu item"
3. Click the Add Item button.
4. Type an ID in the Data Source ID field.
5. Click in the Query field to open Five's Query Builder.
data:image/s3,"s3://crabby-images/1e3e3/1e3e3022296945e599c03c7d6e48f1efc6d82814" alt="Add query"
6. Click the SQL tab.
data:image/s3,"s3://crabby-images/3daaa/3daaaaaaa24ccbf743725c1c089d4b2d8dfe4e69" alt="SQL tab"
7. Add your query.
SELECT
Ingredient.IngredientKey AS IngredientKey,
Ingredient.Name AS Name,
Ingredient.Notes AS Notes
FROM
Ingredient
WHERE
CategoryKey = ?
8. Click the Save button in the Query Builder app bar.
data:image/s3,"s3://crabby-images/273c9/273c94c25b259946940243a1e9026dab16dbabcf" alt="Save button"
9. Click the Parameters tab.
data:image/s3,"s3://crabby-images/192bd/192bd5f74c6d8f850132ff8034ffc4fb7af747c8" alt="Parameters tab"
10. Click the Add Parameters button.
data:image/s3,"s3://crabby-images/4b9e3/4b9e3f35883eaafe2c07aa22e7e103dd3758e7fd" alt="Add Parameters button"
11. Type an ID in the Parameter ID field.
12. Type the parameter in the Parameter field. Example
data:image/s3,"s3://crabby-images/6c49c/6c49cd1496eed2360069ecb19c4d62063a8b0871" alt="Add Parameter"
13. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/669d0/669d094025aabc1595a23944bd69e3cad5640c77" alt="Save button"
14. Click the Save button in the form app bar above the list.
data:image/s3,"s3://crabby-images/b14a8/b14a85d8ec244c4f816d19c303da50448bffa10e" alt="Save button"
Add the Function
1. Select Logic in the menu.2. Select Functions in the sub-menu.
data:image/s3,"s3://crabby-images/11eb2/11eb2022a53e92653d2770504ad8681001759b44" alt="Functions menu item"
3. Click the Add Item button.
4. Type an ID in the Function ID field.
data:image/s3,"s3://crabby-images/209e6/209e69274213d826be5ff2f713d752d9b8cf3b18" alt="Add function"
5. Click in the Code field to open Five's Code Editor.
data:image/s3,"s3://crabby-images/2e325/2e3259a950023ea09d3bad8b6d2036d886ddb745" alt="Code field"
6. Type your code.
function DisplayNotes(five, context, result) {
const notes = five.getMetadata('IngredientKey', 'Notes');
if (notes) {
five.alert(notes);
}
return five.success(result);
}
7. Click the Save button in the Code Editor app bar.
data:image/s3,"s3://crabby-images/df849/df849dca058712a916fe6fec8e080425d86fe3ac" alt="Save button"
8. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/b4cca/b4cca8f162e31174e4c286c2446eb8d2e3b8697a" alt="Save button"
Attach the _LookupQuery and the Function
1. Select Visual in the menu.2. Select Forms in the sub-menu.
data:image/s3,"s3://crabby-images/123f0/123f07b60a06e322a53785cb3bef614c96c45685" alt="Forms menu item"
3. Select the record in the list (Shopping Items).
4. Click the Pages tab.
data:image/s3,"s3://crabby-images/6c2b7/6c2b7015b31f45b995dd009e19a2d0b0d87c508f" alt="Pages tab"
5. Select the page record.
data:image/s3,"s3://crabby-images/4e1e5/4e1e503e7b7bb9b293b81a435280a7fa42265111" alt="Page record"
6. Click the Fields tab.
data:image/s3,"s3://crabby-images/5e5b2/5e5b2e37bfe34ccfb7c9428348a165497129bb17" alt="Fields tab"
7. Select the field record (Ingredient).
data:image/s3,"s3://crabby-images/e0f58/e0f5827e1ad68648fcd537686ff0fd3ae4af5e35" alt="Field record"
8. Either click the Edit button in the form app bar or click directly in the Display Type field.
data:image/s3,"s3://crabby-images/018c2/018c260b1204bbf05f8f24f2a8252abf15df8bc4" alt="Edit button"
9. Click the lookup icon in the Display Type field and select _LookupQuery.
10. Click the lookup icon in the Lookup Data Source field and select your query (IngredientLookupQuery).
data:image/s3,"s3://crabby-images/62c2d/62c2d81c149ad413ab2d96a30288fdca8f32d957" alt="Attach the _LookupQuery"
11. Click the Events tab.
data:image/s3,"s3://crabby-images/8d5fc/8d5fc6ea0c714856293e15deb6bf2227607fedf0" alt="Events tab"
12. Click the lookup icon in the On List Select field and select your function (DisplayNotes).
data:image/s3,"s3://crabby-images/a1178/a1178bf14dc9a8b469ef29ec1945945e08db9fd8" alt="On List Select field"
13. Click the Save button in the form app bar.
data:image/s3,"s3://crabby-images/4ad88/4ad886a3c219731f6d13542bc85bcb5b858cf9bb" alt="Save button"
14. Click the Save button in the form app bar above the list.
data:image/s3,"s3://crabby-images/f02ad/f02adb95e1f617c110a507bf9c8fcb07865e4139" alt="Save button"
_LookupQuery in the Form Wizard
If you know you want to use the display type _LookupQuery on creation of your form while using the Form Wizard, select _LookupQuery in the Display Type field. To add the query, you will need to edit the form record as documented above to add the data source ID for the query.
data:image/s3,"s3://crabby-images/e1320/e1320bac55fbd2573ece140a34b0c352cdfa095f" alt="Display Type field"