之前在使用es must和should混合使用的时候,发现should不起作用了。
参考
https://segmentfault.com/q/1010000008089977?_ea=1544390
https://blog.csdn.net/u012116196/article/details/51789253
问题
例如在a=1且b=2的数据中,找出c=1或者d=2的数据
{"query": {
"bool": {
"must": [
{"match": {
"a": "1",
"b": "2"
}}
],
"should": [
{"match": {
"c": "1"
},
{"match": {
"d": "2"
}}
]
}}}
这样写的时候should是没有用的,这是新手可能犯的错误之一。 在编写查询条件的时候,不能用口头上的逻辑进行编写,而是要换成数学逻辑才能进行执行(数据库同理)。 如上例,数学逻辑应该是 (a==1&&b==2&&c==1)||(a==1&&b==2&&d==2)(java and c语言版),这样的结构去查询。
解决
{"query": {
"bool": {
"should": [
{"match": {
"a": "1",
"b": "2",
"c": "1"
}}
],
"should": [
{"match": {
"a": "1",
"b": "2",
"d": "2"
}}
]
}}}
JAVA API
QueryBuilder query = QueryBuilders.boolQuery()
.should(QueryBuilders.boolQuery()
.filter(QueryBuilders.termQuery("a", 1))
.filter(QueryBuilders.termQuery("b", 2))
.filter(QueryBuilders.termQuery("c", 1))
.should(QueryBuilders.boolQuery()
.filter(QueryBuilders.termQuery("a", 1))
.filter(QueryBuilders.termQuery("b", 2))
.filter(QueryBuilders.termQuery("d", 2));