Defining Valid Values
The product provides several options for defining valid values for a column on a table:
• Lookup
• Extendable Lookup
• Control Table
The following provides more information about the functionality of each of the options available for defining valid values for a column.
Lookup
The simplest mechanism for defining valid values for a column on a table is via the Lookup table. This is sometimes referred to as a “simple” lookup to distinguish it from an extendable lookup (described below). Using the lookup table, you can define valid values and their descriptions. When choosing a valid value that is defined by a lookup, a dropdown UI metaphor is used.
The following highlights functionality related to lookups:
• Lookups are associated with a 
Field. The field is defined as a character data type with an extended data type of 
Flag. The field’s label serves as the description for the prompt to select the valid value.
 • The lookup code is limited to four characters and must be all uppercase. If there is any functionality where a valid value in the application must match valid values in an external system, the lookup table may not be the appropriate choice.
• The lookup table does not support additional attributes to be defined for each value. This option is only appropriate when a simple code and description pair is needed.
• The product may also use Lookups to define valid values for functionality unrelated to a column on a table. For example, an algorithm plug-in spot may define an input parameter that supports one or more valid values. The plug-in spot may define the valid values using a lookup, allowing for a simple way to validate the value supplied when invoking the algorithm and to document the valid values.
Extendable Lookup
The extendable lookup provides a way of defining valid values for a column with additional capabilities that are not supported using the Lookup table. When choosing a valid value that is defined by an extendable lookup, a dropdown UI metaphor is used.
The following highlights functionality related to extendable lookups:
• Each Extendable Lookups is defined using a business object.
• A field should be defined for the extendable lookup code. The field defines the label for the lookup code and defines the size of the lookup code. The size is determined based on the business use case. In addition, there are standard fields included in all extendable lookups, including a description, detailed description and an override description (so that implementations can override the description of base delivered values).
• The extendable lookup may define additional information for each value if warranted by the business requirement. See 
Additional Attributes for technical information about additional attributes.
 Control Table
There may be scenarios where a list of valid values warrants a standalone maintenance object, which is considered an administrative or control table object. When choosing a valid value that is defined by a control, either a dropdown UI metaphor or a search metaphor is used, depending on how it has been designed.
The following points highlight some reasons why this option may be chosen:
• The records require a lifecycle such that BO status is warranted.
• The additional attributes are sophisticated enough that they warrant their own column definition rather than relying on using CLOB or flattened characteristic. For example, if a list of information needs to be captured with several attributes in the list and the information in the list needs to be searchable.
In this situation, if a product has provided a control table for this type of functionality, it will be documented fully in the appropriate functional area. If an implementation determines that a custom control table is warranted, all the standard functionality for a maintenance object is required: database tables, maintenance object metadata, appropriate Java maintenance classes, portals, zones, etc. Refer to the Software Development Kit for more information. No further information is provided in this section for this option.
Parent topic