A search strategy defines how a field is indexed and queried. Any field is associated with a default search strategy, primarily based on its data type.
Search strategies are specified in the Data Model Assistant:
when editing a field, its search strategies can be set in the 'Extensions' tab;
at the data model level, custom search strategies can be specified, under 'Extensions > Search' element in the left pane;
Value-labeling is a global feature in EBX® to display user-friendly labels instead of raw values. For example, in the user interface, a foreign key field displays the label of the linked record, or a field based on a static enumeration displays the localized label associated with the raw value, as specified by the data model.
If a field supports value-labeling, the Quick search and the sort in the user interface usually apply on the displayed label, to preserve an intuitive user interface.
There are some exceptions, where raw value is still used by the quick search and the sort operation:
Programmatic labels and programmatic enumeration constraints (a foreign key specifying a TableRefDisplay
or whose display depends on a UILabelRenderer
specified on the target table, or a field constrained by a ConstraintEnumeration
). It is recommended to use alternative solutions (display patterns and foreign keys).
Enumeration constraint defined using another node (<osd:enumeration osd:path=...
). It is recommended to use an alternative solution (a foreign key).
Obviously, if a field is displayed through a UIWidget
(or a UIBean
), to preserve an intuitive user interface, it is expected for the custom component to display the label (or the value, if this field does not enable value-labeling).
In general, the following fields are not included in the Quick search and they are not optimized for other operators:
computed fields with non-local dependency;
inherited fields.
In the specific cases of inherited dataset, history view or mapped tables, legacy search is used. This implies that the size of the table cannot be quickly estimated, and might not be presented in the UI. It also implies that Quick search:
considers all searchable fields (including computed fields with non-local dependency);
behaves like a 'contains' (Lucene syntax cannot be used);
does not support sort by relevancy;
may perform poorly on tables with large volumes.
Regarding the Advanced Search pane, all fields will be available, except those of type osd:locale
which are not defined as enumerations, and those of type osd:resource
.
'Text' | The 'Text' search strategy is intended to contain multiple words, such as descriptions, texts or comments. This strategy supports full-text search and fuzzy search. Sorting, and some functions such as the ‘equals’ and 'starts-with' operators, are irrelevant and are not supported. This strategy is lightweight, consuming little disk space. See also Quick Search |
'Code' | The 'Code' search strategy is intended for codes and identifiers. Values are considered as one single token, allowing any kind of case-sensitive and case-insensitive filter. Full-text search is irrelevant and is replaced by a 'contains'. |
'Name' | The 'Name' search strategy is intended for names and labels that contain only a few words. Besides having the same search capabilities as 'Text', 'Name' strategy also allows sort, and supports the same filters as 'Code'. This strategy has the most capabilities, but consumes more disk space. If the purpose of the field allows it, it is advised to choose the 'Text', 'Code' or 'Excluded from search' strategy, rather than this one. |
The 'Name' strategy is applied to string fields by default, except:
If the field is part of the primary key, it is set by default to 'Code'.
If the field is a foreign key, it is forced to 'Code' and cannot be changed.
If the field has a built-in datatype extending xs:string
, then it has a strategy relevant to its datatype; for instance osd:text
, xs:Name
, osd:email
, osd:html
, etc.
As the default strategy 'Name' can be irrelevant and consumes more disk space, the data model compilation reports warnings for fields with the 'Name' strategy set as default, so as to ensure that strategies are defined on purpose. We advise to choose the 'Text' strategy, when the length of the expected values is greater than 80, as a rough estimate. Long values (> 32766 bytes once encoded into UTF-8) will not be fully indexed with the 'Name' or 'Code' strategy. Quick search is not affected, but sorting will consider only the first 1000 characters, and some operators ('equals' and 'ends-with', SQL DISTINCT and COUNT DISTINCT, ...) will not return the correct results.
Some strategies accept parameters, for example to define stop words, or a specific language. This is done by creating a record in the 'Search strategies' table of the 'Search' data model extension. The new parameterized strategy will be available for selection in the 'Extension' tab, for compatible fields.
Primary key fields must have a sortable search strategy. This excludes the 'Void' strategy for all data types, and the 'Text' strategy for strings.
The 'Excluded from search' (or Void
) strategy deactivates indexing, making filter, search, or sort impossible. It is available for all data types, and is intended for fields that are never queried. Values can still be accessed through their record. Disabling the indexing reduces the disk space consumed and speeds up some operations like data import.
A search strategy can be associated with a field, by means of a search template. This is done in the 'Extension' tab of the field, in the Data Model Assistant. Assigning multiple search strategies to a field requires registering additional search templates into a module. Only the addons EBX® Information Search and EBX® Match and merge are concerned by additional search templates.