Elasticsearch field name aliasing

眉间皱痕 提交于 2019-12-19 22:04:56

问题


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'...


回答1:


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

Sample Mapping:

PUT myindex
{
  "mappings": {
    "_doc": {
      "properties": {
        "firstname": {
          "type": "text"
        },
        "fn": {
          "type": "alias",
          "path": "firstname" 
        }
      }
    }
  }
}

Sample Query:

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.

  • Field alias is only meant to be used when your index has a 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
  • Can be used in querying, aggregations, sorting, highlighting and suggestion operations
  • Target field must be actual field on which inverted index is created
  • Cannot create alias of another alias field
  • Cannot use alias on multiple fields. Single alias, Single field.
  • Cannot be used as part of source filtering using _source.



回答2:


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




回答3:


Probably you can try creating an alias on your index with filter on the desired field. Your filter must be written in such a way that it selects all the entries from your field. Please refer Filtered aliases section in here. But I am interested in knowing your use case. Why you want to create alias on particular field.



来源:https://stackoverflow.com/questions/28497771/elasticsearch-field-name-aliasing

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!