原英文版地址: https://www.elastic.co/guide/en/elasticsearch/reference/7.7/alias.html, 原文档版权归 www.elastic.co 所有
本地英文版地址: ../en/alias.html

alias(别名)

alias(别名) 映射为索引中的字段定义了一个备用名称。 alias(别名)可以用来代替search请求中的目标字段,以及字段功能等选定的其他API。

PUT /trips
{
  "mappings": {
    "properties": {
      "distance": {
        "type": "long"
      },
      "route_length_miles": {
        "type": "alias",
        "path": "distance" 
      },
      "transit_mode": {
        "type": "keyword"
      }
    }
  }
}

GET /_search
{
  "query": {
    "range" : {
      "route_length_miles" : {
        "gte" : 39
      }
    }
  }
}

目标字段的路径。 注意,这里必须是完整路径,包括任何父对象(例如 object1.object2.field)。

几乎所有搜索请求的组件都接受字段别名。 特别是,别名可用于查询、聚合和排序字段,以及请求docvalue_fieldsstored_fields、建议和高亮显示。 访问字段值时,脚本也支持别名。 请参阅不支持的API部分章节以了解异常情况。

在搜索请求的某些部分及请求字段功能时,可以提供字段通配符模式。 在这些情况下,除了具体字段之外,通配符模式还将匹配字段别名:

GET /trips/_field_caps?fields=route_*,transit_mode

别名目标

别名的目标有一些限制:

  • 目标必须是具体的字段,而不是对象或另一个字段别名。
  • 创建别名时,目标字段必须存在。
  • 如果定义了嵌套对象,字段别名必须具有与其目标相同的嵌套范围。

此外,字段别名只能有一个目标。 这意味着不可能使用字段别名在单个子句中查询多个目标字段。

通过映射更新,可以更改别名以引用新目标。 一个已知的限制是,如果任何存储的 percolator 查询包含字段别名,它们仍将引用其原始目标。 更多信息可以在percolator文档中找到。

不支持的API

不支持写入字段别名:试图在编制索引或更新请求中使用别名将导致失败。 同样,别名不能用作copy_to的目标,也不能用于多字段。

因为文档的源中不存在别名,所以在执行源过滤时不能使用别名。 例如,以下请求将为_source返回一个空结果:

GET /_search
{
  "query" : {
    "match_all": {}
  },
  "_source": "route_length_miles"
}

目前,只有搜索和字段功能API将接受和解析字段别名。 其他接受字段名的API(如term vectors)不能与字段别名一起使用。

最后,一些查询,比如termsgeo_shapemore_like_this,允许从索引文档中获取查询信息。 因为提取文档时不支持字段别名,所以指定查找路径的查询部分不能通过别名引用字段。