elasticsearch中must和should组合查询

引言

  之前在使用es must和should混合使用的时候,发现should不起作用了。

  es版本5.6

参考

  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));

转载于:https://www.cnblogs.com/end-emptiness/p/10267989.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值