这是有关条款的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" } } } }'
但发生错误。期待您的帮助。谢谢!
术语查找机制基本上是一种内置的优化,无需对两个索引JOIN进行两次查询,即在索引A中进行一次查询以获取要查找的ID,而在索引B中进行第二次获取具有这些ID的文档。
与SQL相反,这种JOIN只能在id
字段上工作,因为这是通过GET调用从Elasticsearch唯一检索文档的唯一方法,这正是Elasticsearch在terms
查找中所做的。
因此,要回答您的问题,术语查找机制将不适用于该字段以外的任何其他字段,id
因为要检索的第一个文档必须是唯一的。在您的情况下,ES不会知道如何为用户获取文档,name
Jane
因为name
它只是用户文档中存在的字段,而绝不会为user唯一标识Jane
。