Is it possible to setup alias for field names in elasticsearch? (Just like how index names can be aliased)
For example: i have a document {'firstname': 'John', 'lastname': 'smith'}
I would like to alias 'firstname' to 'fn'...
Just a quick update, Elasticsearch 6.4
came up with feature called Alias Datatype. Check the below mapping and query as sample.
Note that the type of the field is alias
in the below mapping for fieldname fn
PUT myindex
{
"mappings": {
"_doc": {
"properties": {
"firstname": {
"type": "text"
},
"fn": {
"type": "alias",
"path": "firstname"
}
}
}
}
}
GET myindex/_search
{
"query": {
"match" : {
"fn" : "Steve"
}
}
}
The idea is to use the alias
for actual field on which inverted index is created. Note that fields with alias datatype aren't meant for write
operations and its only meant for querying purpose.
Although you can refer to the link I've mentioned for more details, below are just some of the important points.
single mapping
. Index has to be created post 6.xx
version or be created in older version with the setting index.mapping.single_type: true
querying
, aggregations
, sorting
, highlighting
and suggestion
operationsalias
of another alias
fieldalias
on multiple fields. Single alias, Single field._source
. There is no direct field alias functionality. However, you could rename the fields upon indexing using the index_name property in your mappings.
index_name : The name of the field that will be stored in the index. Defaults to the property/field name.
See here for more information: http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/mapping-core-types.html
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With