Update field mappings
Adds new fields to an existing data stream or index. You can also use this API to change the search settings of existing fields. For data streams, these changes are applied to all backing indices by default.
Path parameters
-
A comma-separated list of index names the mapping should be added to (supports wildcards); use
_all
or omit to add the mapping on all indices.
Query parameters
-
allow_no_indices boolean
If
false
, the request returns an error if any wildcard expression, index alias, or_all
value targets only missing or closed indices. This behavior applies even if the request targets other open indices. -
expand_wildcards string | array[string]
Type of index that wildcard patterns can match. If the request can target data streams, this argument determines whether wildcard expressions match hidden data streams. Supports comma-separated values, such as
open,hidden
. Valid values are:all
,open
,closed
,hidden
,none
. -
master_timeout string
Period to wait for a connection to the master node. If no response is received before the timeout expires, the request fails and returns an error.
-
timeout string
Period to wait for a response. If no response is received before the timeout expires, the request fails and returns an error.
-
write_index_only boolean
If
true
, the mappings are applied only to the current write index for the target.
Body Required
-
date_detection boolean
Controls whether dynamic date detection is enabled.
-
dynamic string
Values are
strict
,runtime
,true
, orfalse
. -
dynamic_date_formats array[string]
If date detection is enabled then new string fields are checked against 'dynamic_date_formats' and if the value matches then a new date field is added instead of string.
dynamic_templates object | array[object]
Specify dynamic templates for the mapping.
-
_field_names object
Additional properties are allowed.
-
_meta object
-
numeric_detection boolean
Automatically map strings into numeric data types for all fields.
-
properties object
Mapping for a field. For new fields, this mapping can include:
- Field name
- Field data type
- Mapping parameters
-
_routing object
Additional properties are allowed.
-
_source object
Additional properties are allowed.
-
runtime object
curl \
-X PUT http://api.example.com/{index}/_mapping \
-H "Content-Type: application/json" \
-d '"{\n \"properties\": {\n \"email\": {\n \"type\": \"keyword\"\n }\n }\n}"'
{
"properties": {
"email": {
"type": "keyword"
}
}
}
{
"acknowledged": true,
"_shards": {
"failed": 42.0,
"successful": 42.0,
"total": 42.0,
"failures": [
{
"index": "string",
"node": "string",
"reason": {
"type": "string",
"reason": "string",
"stack_trace": "string",
"caused_by": {},
"root_cause": [
{}
],
"suppressed": [
{}
]
},
"shard": 42.0,
"status": "string"
}
],
"skipped": 42.0
}
}