Dynamic Fields Explained
Locator comes with a large number of factory prepared search fields that are tailored to known and well established Locator use cases across the Ayfie customer base. In addition Locator also has what is referred to as dynamic search fields that are template type fields that can be used as the basis for creating new customized search field on the fly to address unique customer requirements.
How to create, change and benefit from these dynamic fields is not part of this documentation, but covered in other guides and tutorials. This documentation has the narrow goal of just detailing the ability of each dynamic field.
To access the dynamic fields of any Locator instance, look up the file schema.xml in SOLR:
Which dynamic field to use in each case dependent on the use case. What is the data type? Is it a string, a int or a date? Is the data to be part of the search result, or not? Is the data to be indexed and become searchable? Is the data a single value or an array of values? Is the data to be used in a refiner and would thus benefit from being structured differently for faster performance?
There is a one to one mapping between the answers to the questions above and the field name prefix to use. This is the prefix template where the t will be substituted by other letters and the s, i, m and d possibly removed:
via_Tsimd_
Imagine we are to make a index field that is to hold company names. The full field name template would be something like this.
via_Tsimd_company
Here is a description of what to keep and what to change in the prefix:
via - it is a fixed mandatory prefix that is short for viaWorks that was an earlier product name for Locator. The prefix is used to differentiate between original SOLR fields and fields added by Ayfie during development.
T - type is mandatory and the T is a placeholder for anything from 1 to 3 other characters indicating the type: b, dtp, ll, lt, lp, nav, s, t, dbp, fp, ip
s - stored (s) or not stored (nothing) indicates whether the field will be part of the search result or not
i - indexed (i) or not indexed (nothing) indicates whether one will be able to search for the data in the field or not
m - multi valued (m) or single valued (nothing) indicates whether the field hold a single value or an array of values
d - docValues makes refiners performs faster
The table below list all dynamic fields in Locator post version 3.x:
Field Name Prefix | Legacy Prefix | Data Type | in Search result (s) | Indexed (i) | Multivalued (m) | Doc (d) |
---|---|---|---|---|---|---|
via_bi_ | via_geo_b_ | Boolean (b) |
| Yes |
|
|
via_bid_ |
| Boolean (b) |
| Yes |
| Yes |
via_bsid_ |
| Boolean (b) | Yes | Yes |
| Yes |
via_dtpid_ | via_d_ / via_dttid_ | Date (dtp) |
| Yes |
| Yes |
via_dtpsid_ | via_dttsid_ | Date (dtp) | Yes | Yes |
| Yes |
via_dtpimd_ | via_dm_ / via_dttimd_ | Date (dtp) |
| Yes |
| Yes |
via_dtpsimd_ | via_dttsimd_ | Date (dtp) | Yes | Yes |
|
|
via_lli_ | via_geo_p_ | Latitude-Longitude (ll) |
| Yes |
|
|
via_ltid_ |
| Long (lt) |
| Yes |
| Yes |
via_ltimd_ |
| Long (lt) |
| Yes | Yes | Yes |
via_lpid_ |
| Long (lp) |
| Yes |
| Yes |
via_lpimd_ |
| Long (lp) |
| Yes | Yes | Yes |
via_navim_ | via_navm_ | NavigationPath (nav) |
| Yes | Yes |
|
via_sid_ | via_str_ | String (s) |
| Yes |
| Yes |
via_ssid_ |
| String (s) | Yes | Yes |
| Yes |
via_simd_ | via_strm_ / via_geo_str_ | String (s) |
| Yes | Yes | Yes |
via_ssimd_ |
| String (s) | Yes | Yes | Yes | Yes |
via_ti_ | via_tg_ | Text (t) |
| Yes |
|
|
via_tsi_ |
| Text (t) | Yes | Yes |
|
|
via_tim_ | via_tgm_ | Text (t) |
| Yes | Yes |
|
via_tsim_ |
| Text (t) | Yes | Yes | Yes |
|
via_dbpid_ | via_dbtid_ | Double (dbp) |
| Yes |
| Yes |
via_dbpsid_ | via_dbpsid_ | Double (dbp) | Yes | Yes |
| Yes |
via_fpid_ | via_ftid_ | Float (fp) |
| Yes | Yes |
|
via_fpsid_ | via_ftsid_ | Float (fp) | Yes | Yes |
| Yes |
via_ipid_ | via_itid_ | Integer (ip) |
| Yes |
| Yes |
via_ipsid_ | via_itsid_ | Integer (ip) | Yes | Yes |
| Yes |
The Legacy Prefix column refer to the field names used in Locator 2.x and earlier.