弹性搜索:查询多个字段 [英] Elastic Search: Query on multiple fields
本文介绍了弹性搜索:查询多个字段的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我在弹性搜索中具有JSON文档,如下所示
I have JSON document in elastic search as follows
{
"animals": [
{
"id": 1,
"name": "cat"
},
{
"id": 2,
"name": "dog"
},
{
"id": 3,
"name": "rabbit"
}
]
}
只有当所有三种动物都存在时,如何查询才能返回此文档?
How to query return this document only when all the three animals are present?
这不起作用.
curl -H 'Content-Type: application/json' -XPOST http://localhost:9200/*animals*/_search -d '{
"query": {
"bool": {
"must": [
{
"term": {
"animals.name.keyword": "dog"
}
},
{
"term": {
"animals.name.keyword": "cat"
}
},
{
"term": {
"animals.name.keyword": "rabbit"
}
}
],
"must_not": [],
"should": []
}
}
}'
推荐答案
要实现所需的功能,请确保动物
在索引映射中为嵌套类型:
In order to achieve what you want to need to make sure that animals
is of nested type in your index mapping:
PUT animals
{
"mappings": {
"properties": {
"animals": {
"type": "nested"
}
}
}
}
然后您的查询需要如下所示:
Then your query needs to look like this:
curl -H 'Content-Type: application/json' -XPOST http://localhost:9200/*animals*/_search -d '{
"query": {
"bool": {
"must": [
{
"nested": {
"path": "animals",
"query": {
"term": {
"animals.name.keyword": "dog"
}
}
}
},
{
"nested": {
"path": "animals",
"query": {
"term": {
"animals.name.keyword": "cat"
}
}
}
},
{
"nested": {
"path": "animals",
"query": {
"term": {
"animals.name.keyword": "rabbit"
}
}
}
}
]
}
}
}'
这篇关于弹性搜索:查询多个字段的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文