Mapping Definition Examples
Mapping Definition Examples
A mapping definition has the following properties:
-
A
content
array, where each string element (that is, each rule) must follow the mapping rule syntax (see Mapping Rule Syntax Reference).The
content
array elements of a mapping (its rules) are evaluated sequentially.As soon as a rule yields a non-null value, the Coveo indexing pipeline uses this value to populate the target field, and the sequential evaluation ends.
This implies that if the first rule of a mapping contains a hardcoded string (for example,
"My string"
), this rule will always populate the target field, and none of the subsequent rules will be evaluated. -
The name of the target
field
that should be populated with the first non-null value yielded by a rule from thecontent
array. This field must exist in the target Coveo organization index. See Create fields with the API for details on field creation.
Mapping a Metadata to a Field of the Same Name
This is the most basic kind of mapping you can define.
{
"content": [
"%[product_name]"
],
"field": "product_name"
}
By default, the Coveo indexing pipeline automatically tries to use incoming Push source item metadata to populate the field whose name matches that of this metadata key.
This means that in a Push source, you never need to explicitly define mapping rules where the incoming metadata key and target field names are identical.
This also implies that each metadata you want this default mapping behavior to apply to in a Push source must have a field of the same name in the target Coveo organization index. See Create fields with the API for details on field creation.
Mapping a Metadata to a Field with a Different Name
You may want to map metadata and fields whose names differ.
A common use case for this is when your index contains a field whose name is prefixed for a certain source, but whose purpose is identical to that of the corresponding un-prefixed standard field (for example, the mysource_date
field could serve the same purpose as the date
field, but be specific to the mysource
source).
{
"content": [
"%[author]"
],
"field": "mysource_author"
}
Mapping a Concatenated String to a Field
The mapping rule syntax allows you to combine many metadata references and hardcoded strings into a single mapping rule. When such a rule applies, its target field is populated by the resulting concatenated string.
{
"content": [
"%[civic_number], %[street_name]"
],
"field": "address"
}
Defining Several Alternative Mapping Rules for a Field
When a certain mapping includes more than one rule, those rules are evaluated sequentially.
In this example, the rating
field may be populated by one of three distinct rules, depending on what metadata is available when an item passes through the Coveo indexing pipeline:
- If the item has an
internal_rating
metadata value, this value populates the field. - Otherwise, if the item has an
external_rating
metadata value, this value populates the field. - Finally, if all else fails, the
"No rating"
hardcoded string populates the field.
{
"content": [
"%[internal_rating]",
"%[external_rating]",
"No rating"
],
"field": "rating"
}