ElasticSearch中的should 用法

有一个场景需要实现 es_table中 isMember = 1 和 isMember !=1

其中isMember!=1有两种可能: isMember = 0 或者 isMember不存在 

这种情况需要用到should关键词,同时 跟其他条件 例如注册年在2023 是并列的关系

脚本需要用should包含 两个条件 isMember = 0 或者 isMember不存在 

GET es_table/_count
{
  "query": {
    "bool": {
      "should": [
        {
          "bool": {
            "must": [
              {
                "terms": {
                  "isMember": [
                    0
                  ]
                }
              }
            ]
          }
        },
        {
          "bool": {
            "must_not": [
              {
                "exists": {
                  "field": "isMember"
                }
              }
            ]
          }
        }
      ]
    }
  }
}

if (null != isMember) {
   if (1 == isMember) builder.must(QueryBuilders.termQuery("isMember", isMember));
   else if (0 == isMember) {
      //非会员的筛选改为 不是1的isMember数据
      BoolQueryBuilder notMember = QueryBuilders.boolQuery() ;
      notMember.should(QueryBuilders.termQuery("isMember", 0));
            notMember.should(QueryBuilders.boolQuery().mustNot(QueryBuilders.existsQuery("isMember")));
      builder.must(notMember);
   }
}
if(StringUtils.isNotBlank(phone)){
   builder.must(QueryBuilders.termsQuery("phone.keyword", phone, H.phoneAesEncrypt(phone)));
}

如果直接在外层 达不到理想的想过 should变成外层条件了

        builder.should(QueryBuilders.boolQuery()
                        .must(QueryBuilders.termsQuery("isMember", 0)));

        builder.should(QueryBuilders.boolQuery()
                        .mustNot(QueryBuilders.existsQuery("isMember")));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值