一尘不染

条款查询机制可以通过ID以外的其他字段查询吗?

elasticsearch

这是有关条款的Elasticsearch官方网站:https :
//www.elastic.co/guide/en/elasticsearch/reference/2.1/query-dsl-terms-
query.html

如我们所见,如果要进行术语查找机制查询,则应使用如下命令:

curl -XGET localhost:9200/tweets/_search -d '{
  "query" : {
    "terms" : {
      "user" : {
        "index" : "users",
        "type" : "user",
        "id" : "2",
        "path" : "followers"
      }
    }
  }
}'

但是,如果我想通过其他用户领域进行查询怎么办。假设用户还有其他一些字段,例如名称,我是否可以使用术语查找机制通过给用户提供名称(而不提供ID)来查找推文。我试图使用这样的命令:

curl -XGET localhost:9200/tweets/_search -d '{
  "query" : {
    "terms" : {
      "user" : {
        "index" : "users",
        "type" : "user",
        "name" : "Jane",
        "path" : "followers"
      }
    }
  }
}'

但发生错误。期待您的帮助。谢谢!


阅读 218

收藏
2020-06-22

共1个答案

一尘不染

术语查找机制基本上是一种内置的优化,无需对两个索引JOIN进行两次查询,即在索引A中进行一次查询以获取要查找的ID,而在索引B中进行第二次获取具有这些ID的文档。

与SQL相反,这种JOIN只能在id字段上工作,因为这是通过GET调用从Elasticsearch唯一检索文档的唯一方法,这正是Elasticsearch在terms查询中所做的。

因此,要回答您的问题,术语检索机制将不适用于该字段以外的任何其他字段,id因为要检索的第一个文档必须是唯一的。在您的情况下,ES不会知道如何为用户获取文档,name
Jane因为name它只是用户文档中存在的字段,而绝不会为user唯一标识Jane

2020-06-22