ElasticSearch 复合查询 Boolean Query

30 篇文章 0 订阅
21 篇文章 0 订阅

官网文档网址:Boolean query | Elasticsearch Guide [7.17] | Elastic

目录

复合查询 Boolean Query

利用bool查询实现功能

 总结


复合查询 Boolean Query

布尔查询是一个或多个查询子句的组合。子查询的组合方式有:

  • must:必须匹配每个子查询,类似“与
  • should:选择性匹配子查询,类似“或”
  • must not:必须不匹配,不参与算分,类似“非
  • filter:必须匹配,不参与算分

利用bool查询实现功能

案例:搜索名字包含“如家”,价格不高于400,在坐标31.21121.5周围10km范围内的酒店

GET   /hotel/_search

{

        "query" : {

                "bool" : {

                        "must" : [

                                 {
                                "match": {"name":"如家"}

                                }

                        ],
                        "must_not" : [

                                {
                                "range": { "price": { "gt" : 400 }}

                                }

                        ],

                        "filter" : [

                                {
                                        "geo_distance" : {

                                                "distance":"10km" ,

                                                "location": "lat": 31.21 , "lon": 121.5}

                                        }

                                }

                        ]

                }

        } 

}

 总结

bool查询有几种逻辑关系?

  • must:必须匹配的条件,可以理解为 "与"
  • should:选择性匹配的条件,可以理解为 "或"
  • must_not:必须不匹配的条件,不参与打分
  • filter:必须匹配的条件,不参与打分
  • 28
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis的QueryWrapper类中的boolean类型参数用于设置条件的逻辑连接方式。具体来说,它用于指定多个条件之间的关系,包括与运算和或运算。通过设置boolean类型参数,您可以灵活地组合多个条件以满足您的查询需求。 在QueryWrapper类中,有三个主要的boolean类型参数可以使用: 1. and(boolean condition):该方法用于实现与运算,将多个条件用与运算连接起来。当参数condition为true时,表示与运算;当参数condition为false时,则忽略该条件。 2. or(boolean condition):该方法用于实现或运算,将多个条件用或运算连接起来。当参数condition为true时,表示或运算;当参数condition为false时,则忽略该条件。 3. nested(boolean condition):该方法用于实现括号内的条件。当参数condition为true时,表示括号内的条件有效;当参数condition为false时,则忽略括号内的条件。 通过使用这些boolean类型参数,您可以根据需要创建复杂的条件查询,满足更加具体的查询需求。例如,您可以使用and和or方法来组合多个条件,并使用nested方法来创建嵌套条件。您还可以结合其他方法,如eq、like、gt等,来定义具体的条件表达式。 以下是一个示例代码,演示了如何在Mybatis中使用QueryWrapper的boolean类型参数: ``` @Test void testQueryWrapper() { QueryWrapper<User> condition = new QueryWrapper<>(); condition.eq("gender", "male").and(wrapper -> wrapper.lt("age", 30).or().gt("salary", 5000)); List<User> users = userMapper.selectList(condition); System.out.println(users); } ``` 在上面的示例中,我们使用了eq方法设置了一个等于条件,并使用and方法和or方法将多个条件组合起来。这样,我们可以查询性别为男性,并且年龄小于30岁或者工资大于5000的用户信息。最后,我们通过selectList方法执行查询,并将结果打印输出。 希望这个例子能够帮助您更好地理解如何在Mybatis中使用QueryWrapper的boolean类型参数。如果您还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值