-
Notifications
You must be signed in to change notification settings - Fork 509
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
- Loading branch information
1 parent
3d20bf8
commit 774de00
Showing
6 changed files
with
385 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
--- | ||
layout: default | ||
title: Analyzer | ||
parent: Mapping parameters | ||
grand_parent: Mapping and field types | ||
nav_order: 5 | ||
has_children: false | ||
has_toc: false | ||
--- | ||
|
||
# Analyzer | ||
|
||
The `analyzer` mapping parameter is used to define the text analysis process that applies to a text field during both index and search operations. | ||
|
||
The key functions of the `analyzer` mapping parameter are: | ||
|
||
1. **Tokenization:** The analyzer determines how the text is broken down into individual tokens (words, numbers) that can be indexed and searched. Each generated token must not exceed 32,766 bytes in order to avoid indexing failures. | ||
|
||
2. **Normalization:** The analyzer can apply various normalization techniques, such as converting text to lowercase, removing stop words, and stemming/lemmatizing words. | ||
|
||
3. **Consistency:** By defining the same analyzer for both index and search operations, you ensure that the text analysis process is consistent, which helps improve the relevance of search results. | ||
|
||
4. **Customization:** OpenSearch allows you to define custom analyzers by specifying the tokenizer, character filters, and token filters to be used. This gives you fine-grained control over the text analysis process. | ||
|
||
For information about specific analyzer parameters, such as `analyzer`, `search_analyzer`, or `search_quote_analyzer`, see [Search analyzers]({{site.url}}{{site.baseurl}}/analyzers/search-analyzers/). | ||
{: .note} | ||
|
||
------------ | ||
|
||
## Example | ||
|
||
The following example configuration defines a custom analyzer called `my_custom_analyzer`: | ||
|
||
```json | ||
PUT my_index | ||
{ | ||
"settings": { | ||
"analysis": { | ||
"analyzer": { | ||
"my_custom_analyzer": { | ||
"type": "custom", | ||
"tokenizer": "standard", | ||
"filter": [ | ||
"lowercase", | ||
"my_stop_filter", | ||
"my_stemmer" | ||
] | ||
} | ||
}, | ||
"filter": { | ||
"my_stop_filter": { | ||
"type": "stop", | ||
"stopwords": ["the", "a", "and", "or"] | ||
}, | ||
"my_stemmer": { | ||
"type": "stemmer", | ||
"language": "english" | ||
} | ||
} | ||
} | ||
}, | ||
"mappings": { | ||
"properties": { | ||
"my_text_field": { | ||
"type": "text", | ||
"analyzer": "my_custom_analyzer", | ||
"search_analyzer": "standard", | ||
"search_quote_analyzer": "my_custom_analyzer" | ||
} | ||
} | ||
} | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the `my_custom_analyzer` uses the standard tokenizer, converts all tokens to lowercase, applies a custom stop word filter, and applies an English stemmer. | ||
|
||
You can then map a text field so that it uses this custom analyzer for both index and search operations: | ||
|
||
```json | ||
"mappings": { | ||
"properties": { | ||
"my_text_field": { | ||
"type": "text", | ||
"analyzer": "my_custom_analyzer" | ||
} | ||
} | ||
} | ||
``` | ||
{% include copy-curl.html %} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
--- | ||
layout: default | ||
title: Boost | ||
parent: Mapping parameters | ||
grand_parent: Mapping and field types | ||
nav_order: 10 | ||
has_children: false | ||
has_toc: false | ||
--- | ||
|
||
# Boost | ||
|
||
The `boost` mapping parameter is used to increase or decrease the relevance score of a field during search queries. It allows you to apply more or less weight to specific fields when calculating the overall relevance score of a document. | ||
|
||
The `boost` parameter is applied as a multiplier to the score of a field. For example, if a field has a `boost` value of `2`, then the score contribution of that field is doubled. Conversely, a `boost` value of `0.5` would halve the score contribution of that field. | ||
|
||
----------- | ||
|
||
## Example | ||
|
||
The following is an example of how you can use the `boost` parameter in an OpenSearch mapping: | ||
|
||
```json | ||
PUT my-index1 | ||
{ | ||
"mappings": { | ||
"properties": { | ||
"title": { | ||
"type": "text", | ||
"boost": 2 | ||
}, | ||
"description": { | ||
"type": "text", | ||
"boost": 1 | ||
}, | ||
"tags": { | ||
"type": "keyword", | ||
"boost": 1.5 | ||
} | ||
} | ||
} | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the `title` field has a boost of `2`, which means that it contributes twice as much to the overall relevance score than the description field (which has a boost of `1`). The `tags` field has a boost of `1.5`, so it contributes one and a half times more than the description field. | ||
|
||
The `boost` parameter is particularly useful when you want to apply more weight to certain fields. For example, you might want to boost the `title` field more than the `description` field because the title may be a better indicator of the document's relevance. | ||
|
||
The `boost` parameter is a multiplicative factor---not an additive one. This means that a field with a higher boost value will have a disproportionately large effect on the overall relevance score as compared to fields with lower boost values. When using the `boost` parameter, it is recommended that you start with small values (1.5 or 2) and test the effect on your search results. Overly high boost values can skew the relevance scores and lead to unexpected or undesirable search results. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
--- | ||
layout: default | ||
title: Coerce | ||
parent: Mapping parameters | ||
grand_parent: Mapping and field types | ||
nav_order: 15 | ||
has_children: false | ||
has_toc: false | ||
--- | ||
|
||
# Coerce | ||
|
||
The `coerce` mapping parameter controls how values are converted to the expected field data type during indexing. This parameter lets you verify that your data is formatted and indexed properly, following the expected field types. This improves the accuracy of your search results. | ||
|
||
--- | ||
|
||
## Examples | ||
|
||
The following examples demonstrate how to use the `coerce` mapping parameter. | ||
|
||
#### Indexing a document with `coerce` enabled | ||
|
||
```json | ||
PUT products | ||
{ | ||
"mappings": { | ||
"properties": { | ||
"price": { | ||
"type": "integer", | ||
"coerce": true | ||
} | ||
} | ||
} | ||
} | ||
|
||
PUT products/_doc/1 | ||
{ | ||
"name": "Product A", | ||
"price": "19.99" | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the `price` field is defined as an `integer` type with `coerce` set to `true`. When indexing the document, the string value `19.99` is coerced to the integer `19`. | ||
|
||
#### Indexing a document with `coerce` disabled | ||
|
||
```json | ||
PUT orders | ||
{ | ||
"mappings": { | ||
"properties": { | ||
"quantity": { | ||
"type": "integer", | ||
"coerce": false | ||
} | ||
} | ||
} | ||
} | ||
|
||
PUT orders/_doc/1 | ||
{ | ||
"item": "Widget", | ||
"quantity": "10" | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the `quantity` field is defined as an `integer` type with `coerce` set to `false`. When indexing the document, the string value `10` is not coerced, and the document is rejected because of the type mismatch. | ||
|
||
#### Setting the index-level coercion setting | ||
|
||
```json | ||
PUT inventory | ||
{ | ||
"settings": { | ||
"index.mapping.coerce": false | ||
}, | ||
"mappings": { | ||
"properties": { | ||
"stock_count": { | ||
"type": "integer", | ||
"coerce": true | ||
}, | ||
"sku": { | ||
"type": "keyword" | ||
} | ||
} | ||
} | ||
} | ||
|
||
PUT inventory/_doc/1 | ||
{ | ||
"sku": "ABC123", | ||
"stock_count": "50" | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the index-level `index.mapping.coerce` setting is set to `false`, which disables coercion for the index. However, the `stock_count` field overrides this setting and enables coercion for this specific field. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,109 @@ | ||
--- | ||
layout: default | ||
title: Copy_to | ||
parent: Mapping parameters | ||
grand_parent: Mapping and field types | ||
nav_order: 20 | ||
has_children: false | ||
has_toc: false | ||
--- | ||
|
||
# Copy_to | ||
|
||
The `copy_to` parameter allows you to copy the values of multiple fields into a single field. This parameter can be useful if you often search across multiple fields because it allows you to search the group field instead. | ||
|
||
Only the field value is copied and not the terms resulting from the analysis process. The original `_source` field remains unmodified, and the same value can be copied to multiple fields using the `copy_to` parameter. However, recursive copying through intermediary fields is not supported; instead, use `copy_to` directly from the originating field to multiple target fields. | ||
|
||
--- | ||
|
||
## Examples | ||
|
||
The following example uses the `copy_to` parameter to search for products by their name and description and copy those values into a single field: | ||
|
||
```json | ||
PUT my-products-index | ||
{ | ||
"mappings": { | ||
"properties": { | ||
"name": { | ||
"type": "text", | ||
"copy_to": "product_info" | ||
}, | ||
"description": { | ||
"type": "text", | ||
"copy_to": "product_info" | ||
}, | ||
"product_info": { | ||
"type": "text" | ||
}, | ||
"price": { | ||
"type": "float" | ||
} | ||
} | ||
} | ||
} | ||
|
||
PUT my-products-index/_doc/1 | ||
{ | ||
"name": "Wireless Headphones", | ||
"description": "High-quality wireless headphones with noise cancellation", | ||
"price": 99.99 | ||
} | ||
|
||
PUT my-products-index/_doc/2 | ||
{ | ||
"name": "Bluetooth Speaker", | ||
"description": "Portable Bluetooth speaker with long battery life", | ||
"price": 49.99 | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
In this example, the values from the `name` and `description` fields are copied into the `product_info` field. You can now search for products by querying the `product_info` field, as follows: | ||
|
||
```json | ||
GET my-products-index/_search | ||
{ | ||
"query": { | ||
"match": { | ||
"product_info": "wireless headphones" | ||
} | ||
} | ||
} | ||
``` | ||
{% include copy-curl.html %} | ||
|
||
## Response | ||
|
||
```json | ||
{ | ||
"took": 20, | ||
"timed_out": false, | ||
"_shards": { | ||
"total": 1, | ||
"successful": 1, | ||
"skipped": 0, | ||
"failed": 0 | ||
}, | ||
"hits": { | ||
"total": { | ||
"value": 1, | ||
"relation": "eq" | ||
}, | ||
"max_score": 1.9061546, | ||
"hits": [ | ||
{ | ||
"_index": "my-products-index", | ||
"_id": "1", | ||
"_score": 1.9061546, | ||
"_source": { | ||
"name": "Wireless Headphones", | ||
"description": "High-quality wireless headphones with noise cancellation", | ||
"price": 99.99 | ||
} | ||
} | ||
] | ||
} | ||
} | ||
``` | ||
|
12 changes: 8 additions & 4 deletions
12
_field-types/dynamic.md → _field-types/mapping-parameters/dynamic.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.