这是有关条款的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)
但发生错误。期待您的帮助。谢谢!
我认为您并没有完全理解这是如何工作的。术语查找查询的工作原理是从具有给定 ID 的文档字段中读取值。在这种情况下,您尝试将索引user中的字段值tweets与索引和类型中存在followersid 的文档中的字段值进行匹配。"2"usersuser
如果您想阅读任何其他领域的内容,只需在 中提及即可"path"。
您主要需要了解的是,查找值都是从单个文档的字段中获取的,而不是从多个文档中获取的。
术语查找机制基本上是一种内置的优化,无需对两个索引JOIN进行两次查询,即在索引A中进行一次查询以获取要查找的ID,而在索引B中进行第二次获取具有这些ID的文档。
与SQL相反,这种JOIN只能在id字段上工作,因为这是通过GET调用从Elasticsearch唯一检索文档的唯一方法,这正是Elasticsearch在terms查找中所做的。
因此,要回答您的问题,术语查找机制将不适用于该字段以外的任何其他字段,id因为要检索的第一个文档必须是唯一的。在您的情况下,ES不会知道如何为用户获取文档,name Jane因为name它只是用户文档中存在的字段,而绝不会为user唯一标识Jane。
| 归档时间: |
|
| 查看次数: |
2430 次 |
| 最近记录: |