| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 | [[multi-fields]]=== `fields`It is often useful to index the same field in different ways for differentpurposes.  This is the purpose of _multi-fields_. For instance, a `string`field could be mapped as a `text` field for full-textsearch, and as a `keyword` field for sorting or aggregations:[source,js]--------------------------------------------------PUT my_index{  "mappings": {    "properties": {      "city": {        "type": "text",        "fields": {          "raw": { <1>            "type":  "keyword"          }        }      }    }  }}PUT my_index/_doc/1{  "city": "New York"}PUT my_index/_doc/2{  "city": "York"}GET my_index/_search{  "query": {    "match": {      "city": "york" <2>    }  },  "sort": {    "city.raw": "asc" <3>  },  "aggs": {    "Cities": {      "terms": {        "field": "city.raw" <3>      }    }  }}--------------------------------------------------// CONSOLE<1> The `city.raw` field is a `keyword` version of the `city` field.<2> The `city` field can be used for full text search.<3> The `city.raw` field can be used for sorting and aggregationsNOTE: Multi-fields do not change the original `_source` field.TIP: The `fields` setting is allowed to have different settings for fields ofthe same name in the same index.  New multi-fields can be added to existingfields using the <<indices-put-mapping,PUT mapping API>>.==== Multi-fields with multiple analyzersAnother use case of multi-fields is to analyze the same field in differentways for better relevance. For instance we could index a field with the<<analysis-standard-analyzer,`standard` analyzer>> which breaks text up intowords, and again with the <<english-analyzer,`english` analyzer>>which stems words into their root form:[source,js]--------------------------------------------------PUT my_index{  "mappings": {    "properties": {      "text": { <1>        "type": "text",        "fields": {          "english": { <2>            "type":     "text",            "analyzer": "english"          }        }      }    }  }}PUT my_index/_doc/1{ "text": "quick brown fox" } <3>PUT my_index/_doc/2{ "text": "quick brown foxes" } <3>GET my_index/_search{  "query": {    "multi_match": {      "query": "quick brown foxes",      "fields": [ <4>        "text",        "text.english"      ],      "type": "most_fields" <4>    }  }}--------------------------------------------------// CONSOLE<1> The `text` field uses the `standard` analyzer.<2> The `text.english` field uses the `english` analyzer.<3> Index two documents, one with `fox` and the other with `foxes`.<4> Query both the `text` and `text.english` fields and combine the scores.The `text` field contains the term `fox` in the first document and `foxes` inthe second document.  The `text.english` field contains `fox` for bothdocuments, because `foxes` is stemmed to `fox`.The query string is also analyzed by the `standard` analyzer for the `text`field, and by the `english` analyzer for the `text.english` field.  Thestemmed field allows a query for `foxes` to also match the document containingjust `fox`.  This allows us to match as many documents as possible.  By alsoquerying the unstemmed `text` field, we improve the relevance score of thedocument which matches `foxes` exactly.
 |