需求背景:将订单表数据同步至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时搜索条件分词的情况文章来源:https://www.toymoban.com/news/detail-716860.html
我发现我输入“门店”进行查询,会查询到查询field包含“**门**” 、“**店**”、“**门**店**”的情况,但是这种数据不在我的搜索目标内,所以可以使用matchPhraseQuery,matchPhraseQuery只能匹配门店两个词必须相邻的情景文章来源地址https://www.toymoban.com/news/detail-716860.html
到了这里,关于es查询简单场景问题小记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!