es查询简单场景问题小记

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

ps:整合springboot+RestHighLevelClient

文章来源地址https://www.uudwc.com/A/oL6JV/

关于操作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只能匹配门店两个词必须相邻的情景

原文地址:https://blog.csdn.net/sanko33/article/details/129407043

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

上一篇 2023年09月18日 00:26
下一篇 2023年09月18日 00:28