需求背景:将订单表数据同步至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","*&