Terms Query(多项查询)

原文链接 : https://www.elastic.co/guide/en/elasticsearch/reference/current/query-dsl-terms-query.html

译文链接 : http://www.apache.wiki/pages/viewpage.action?pageId=4260558

贡献者 : @小布丁

筛选所拥有的字段能够匹配提供的多个项(not analyzed)中任意一个的文档。

例如:

  1. GET /_search
  2. {
  3. "query": {
  4. "constant_score" : {
  5. "filter" : {
  6. "terms" : { "user" : ["kimchy", "elasticsearch"]}
  7. }
  8. }
  9. }
  10. }

terms Query(多项查询)常常别名后和 in 配合作为筛选器名字的简单用法( 5.0.0 已经弃用)。

Terms (多项)查找机制

当需要用大量的项来指定项过滤器时,它可以有助于从索引中的文档中提取这些项值。一个具体的例子是过滤由你的追随者推送的tweet。在项过滤器中指定的用户ID的数量可以很多。在这种情况下,使用项过滤器的术语查找机制是有意义的。

多项查找机制支持以下项目:

选项 说明
index index (索引)被用来提取项的值。默认当前 index (索引)
type type (类型)被用来提取项的值。
id 用文档 id (ID)来提取项的值。
path 指定为路径的字段,以获取 term (项)筛选器的实际值。
routing 检索外部 term (项)文档时要使用的自定义路由值。

项过滤器的值将从具有指定类型和索引中指定标识的文档中的字段获取。在内部,执行一个获取请求需要从指定的路径获取值。目前这个功能的工作需要存储 _source 。 此外,如果“引用”项数据不大,请考虑使用具有单个分片的索引,并在所有节点中完全复制。如果可能,项查找过滤器将更乐意在本地节点上执行 get 请求,以减少对网络的需求。

Terms (多项)查找 twitter (推特)示例

首先,我们索引 ID 为2的用户的信息,特别是其关注者,索引来自 ID 为1的用户的推文。最后,我们搜索与用户2的关注者匹配的所有tweet。

  1. PUT /users/user/2
  2. {
  3. "followers" : ["1", "3"]
  4. }
  5. PUT /tweets/tweet/1
  6. {
  7. "user" : "1"
  8. }
  9. GET /tweets/_search
  10. {
  11. "query" : {
  12. "terms" : {
  13. "user" : {
  14. "index" : "users",
  15. "type" : "user",
  16. "id" : "2",
  17. "path" : "followers"
  18. }
  19. }
  20. }
  21. }
  1. 外部项文档的结构还可以包括内部对象的数组,例如:
  1. curl -XPUT localhost:9200/users/user/2 -d '{
  2. "followers" : [
  3. {
  4. "id" : "1"
  5. },
  6. {
  7. "id" : "2"
  8. }
  9. ]
  10. }'

在这种情况下,查找路径将是 followers.id