Lookup tables can be used to populate drop down boxes and typeahead autocomplete textbox fields on nForm forms.
Binding Lookups to Form Controls
To bind a lookup table to a Short Text control, select the lookup table from the Data Source drop down menu in the auto-complete settings for the control:
To bind a lookup table to a Single Selection or Multiple Selection control, choose a Data Source Type = "Dynamic", and then select the lookup table from the Dynamic Data Source drop down box:
Performance Tips for Large Lookups
If you have a large lookup table with more than 50 entries, it is recommended that the Short Text control is used. Slow performance can occur when large lookups are bound to a Single Selection or Multiple Selection Control since the entire lookup table is embedded in the form data which must be downloaded to the user's browser.
In contrast, when a Short Text control is used, lookup values are dynamically loaded from the server as the user types, reducing the amount of data sent to the user's browser.
Creating Lookup Tables
Lookup tables must be loaded into the nForm database by inserting directly into the nform.LOOKUP and nform.LOOKUP_VALUE tables.
The nform.LOOKUP table provides a name for the lookup table as displayed in the Data Source drop downs shown above
The nform.LOOKUP_VALUES table will contain a row for each of your lookup values. Note that lookup values can be inactivated by setting the IS_ACTIVE field to 0.
The refreshing of lookup values can be done as part of a periodic manual or automated process.
DECLARE @LOOKUP_ID UNIQUEIDENTIFIER SET @LOOKUP_ID = NEWID() INSERT INTO NFORM.LOOKUP ( LOOKUP_ID , NAME , CREATED_DATE , CREATED_USER , UPDATED_DATE , UPDATED_USER , IS_AVAILABLE_FOR_DROPDOWN ) SELECT @LOOKUP_ID, -- LOOKUP_ID - uniqueidentifier N'COLORS' , -- NAME - nvarchar(255) GETDATE() , -- CREATED_DATE - datetime2 1 , -- CREATED_USER - uniqueidentifier GETDATE() , -- UPDATED_DATE - datetime2 1 , -- UPDATED_USER - uniqueidentifier 1 -- IS_AVAILABLE_FOR_DROPDOWN - bit INSERT INTO NFORM.LOOKUP_VALUE ( LOOKUP_VALUE_ID , LOOKUP_ID , NAME , DESCRIPTION , CREATED_DATE , CREATED_USER , UPDATED_DATE , UPDATED_USER , IS_ACTIVE ) SELECT NEWID() , -- LOOKUP_VALUE_ID - uniqueidentifier @LOOKUP_ID , -- LOOKUP_ID - uniqueidentifier MySourceTable.Name , -- NAME - nvarchar(600) MySourceTable.Description , -- DESCRIPTION - nvarchar(600) GETDATE() , -- CREATED_DATE - datetime2 1 , -- CREATED_USER - uniqueidentifier GETDATE() , -- UPDATED_DATE - datetime2 1 , -- UPDATED_USER - uniqueidentifier MySourceTable.IsActive -- IS_ACTIVE - bit FROM MySourceTable