By default, field values are indexed to make them searchable, but they are not stored. This means that the field can be queried, but the original field value cannot be retrieved.
Usually this doesn’t matter. The field value is already part of the _source
field, which is stored by default. If you only want to retrieve the value of a single field or of a few fields, instead of the whole_source
, then this can be achieved with source filtering.
In certain situations it can make sense to store
a field. For instance, if you have a document with atitle
, a date
, and a very large content
field, you may want to retrieve just the title
and the date
without having to extract those fields from a large _source
field:
PUT my_index
{
"mappings": {
"my_type": {
"properties": {
"title": {
"type": "text",
"store": true
},
"date": {
"type": "date",
"store": true
},
"content": {
"type": "text"
}
}
}
}
}
PUT my_index/my_type/1
{
"title": "Some short title",
"date": "2015-01-01",
"content": "A very long content field..."
}
GET my_index/_search
{
"stored_fields": [ "title", "date" ]
}