Link Search Menu Expand Document Documentation Menu

You're viewing version 2.15 of the OpenSearch documentation. This version is no longer maintained. For the latest version, see the current documentation. For information about OpenSearch version maintenance, see Release Schedule and Maintenance Policy.

Keyword field type

A keyword field type contains a string that is not analyzed. It allows only exact, case-sensitive matches.

By default, keyword fields are both indexed (because index is enabled) and stored on disk (because doc_values is enabled). To reduce disk space, you can specify not to index keyword fields by setting index to false.

If you need to use a field for full-text search, map it as text instead.

Example

The following query creates a mapping with a keyword field. Setting index to false specifies to store the genre field on disk and to retrieve it using doc_values:

PUT movies
{
  "mappings" : {
    "properties" : {
      "genre" : {
        "type" :  "keyword",
        "index" : false
      }
    }
  }
}

Parameters

The following table lists the parameters accepted by keyword field types. All parameters are optional.

Parameter Description
boost A floating-point value that specifies the weight of this field toward the relevance score. Values above 1.0 increase the field’s relevance. Values between 0.0 and 1.0 decrease the field’s relevance. Default is 1.0.
doc_values A Boolean value that specifies whether the field should be stored on disk so that it can be used for aggregations, sorting, or scripting. Default is true.
eager_global_ordinals Specifies whether global ordinals should be loaded eagerly on refresh. If the field is often used for aggregations, this parameter should be set to true. Default is false.
fields To index the same string in several ways (for example, as a keyword and text), provide the fields parameter. You can specify one version of the field to be used for search and another to be used for sorting and aggregations.
ignore_above Any string longer than this integer value should not be indexed. Default is 2147483647. Default dynamic mapping creates a keyword subfield for which ignore_above is set to 256.
index A Boolean value that specifies whether the field should be searchable. Default is true. To reduce disk space, set index to false.
index_options Information to be stored in the index that will be considered when calculating relevance scores. Can be set to freqs for term frequency. Default is docs.
meta Accepts metadata for this field.
normalizer Specifies how to preprocess this field before indexing (for example, make it lowercase). Default is null (no preprocessing).
norms A Boolean value that specifies whether the field length should be used when calculating relevance scores. Default is false.
null_value A value to be used in place of null. Must be of the same type as the field. If this parameter is not specified, the field is treated as missing when its value is null. Default is null.
similarity The ranking algorithm for calculating relevance scores. Default is BM25.
split_queries_on_whitespace A Boolean value that specifies whether full-text queries should be split on white space. Default is false.
store A Boolean value that specifies whether the field value should be stored and can be retrieved separately from the _source field. Default is false.
350 characters left

Have a question? .

Want to contribute? or .