本地英文版地址: ../en/alias.html
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 } } } }
几乎所有搜索请求的组件都接受字段别名。
特别是,别名可用于查询、聚合和排序字段,以及请求docvalue_fields
、stored_fields
、建议和高亮显示。
访问字段值时,脚本也支持别名。
请参阅不支持的API部分章节以了解异常情况。
在搜索请求的某些部分及请求字段功能时,可以提供字段通配符模式。 在这些情况下,除了具体字段之外,通配符模式还将匹配字段别名:
GET /trips/_field_caps?fields=route_*,transit_mode
别名的目标有一些限制:
- 目标必须是具体的字段,而不是对象或另一个字段别名。
- 创建别名时,目标字段必须存在。
- 如果定义了嵌套对象,字段别名必须具有与其目标相同的嵌套范围。
此外,字段别名只能有一个目标。 这意味着不可能使用字段别名在单个子句中查询多个目标字段。
通过映射更新,可以更改别名以引用新目标。 一个已知的限制是,如果任何存储的 percolator 查询包含字段别名,它们仍将引用其原始目标。 更多信息可以在percolator文档中找到。
不支持写入字段别名:试图在编制索引或更新请求中使用别名将导致失败。
同样,别名不能用作copy_to
的目标,也不能用于多字段。
因为文档的源中不存在别名,所以在执行源过滤时不能使用别名。
例如,以下请求将为_source
返回一个空结果:
GET /_search { "query" : { "match_all": {} }, "_source": "route_length_miles" }
目前,只有搜索和字段功能API将接受和解析字段别名。 其他接受字段名的API(如term vectors)不能与字段别名一起使用。
最后,一些查询,比如terms
、geo_shape
和more_like_this
,允许从索引文档中获取查询信息。
因为提取文档时不支持字段别名,所以指定查找路径的查询部分不能通过别名引用字段。