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

iur*_*rti 3 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"
      }
    }
  }
}'
Run Code Online (Sandbox Code Playgroud)

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

curl -XGET localhost:9200/tweets/_search -d '{
  "query" : {
    "terms" : {
      "user" : {
        "index" : "users",
        "type" : "user",
        "name" : "Jane",
        "path" : "followers"
      }
    }
  }
}'  
Run Code Online (Sandbox Code Playgroud)

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

bit*_*kar 5

我认为您并没有完全理解这是如何工作的。术语查找查询的工作原理是从具有给定 ID 的文档字段中读取值。在这种情况下,您尝试将索引user中的字段值tweets与索引和类型中存在followersid 的文档中的字段值进行匹配。"2"usersuser

如果您想阅读任何其他领域的内容,只需在 中提及即可"path"

您主要需要了解的是,查找值都是从单个文档的字段中获取的,而不是从多个文档中获取的。


Val*_*Val 5

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

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

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