es查询简单场景问题小记

需求背景:将订单表数据同步至es,实现根据订单名称、产品名称、客户姓名、客户手机号、备注、供应商姓名进行模糊查询

ps:整合springboot+RestHighLevelClient

关于操作es数据的工具类,网上一抓一大把,我也是随便找了文章,修修改改直接用的

这篇文章主要是想记录一下在查询时遇到的问题

1、关于多条件or查询,可以使用BoolQueryBuilder,must代表必须匹配的条件,should代表可匹配的条件,以下query语句的意思即为:查询数据必须满足匹配orgId的情况,但是name、telephone、remark三者匹配其一即可

BoolQueryBuilder queryBuilder = QueryBuilders.boolQuery()
                .must(QueryBuilders.termQuery("orgId", req.getOrgId()))
                .should(QueryBuilders.matchPhraseQuery("name", req.getSearchWords()))
                .should(QueryBuilders.wildcardQuery("telephone","*" + req.getSearchWords() + "*"))
                .should(QueryBuilders.matchPhraseQuery("remark", req.getSearchWords()))
                .minimumShouldMatch(1);

2、关于手机号模糊搜索,只靠分词是不能实现的,需要用到正则表达式查询wildcardQuery

QueryBuilders.wildcardQuery("telephone","*" + req.getSearchWords() + "*")

3、关于分词器

对于中文,大部分情况都喜欢用ik分词器,但是即使使用ik_maxword分词器也并不能实现所有情况都能查回来,比如“门店客户”可能会被分词器拆分为“门店”、“客户”、“门店客户”,你输入门,是无法查回来这条数据的,如果有这种场景,建议还是使用standard

4、关于使用match时搜索条件分词的情况

我发现我输入“门店”进行查询,会查询到查询field包含“**门**” 、“**店**”、“**门**店**”的情况,但是这种数据不在我的搜索目标内,所以可以使用matchPhraseQuery,matchPhraseQuery只能匹配门店两个词必须相邻的情景

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值