SearchSourceBuilder builder = new SearchSourceBuilder();//查询的bulider,相当于地基,用来构建查询的房子
BoolQueryBuilder boolQueryBuilder = new BoolQueryBuilder();//es的桶操作
boolQueryBuilder.must();这个方法就像sql的and 操作,多个must就相当于and
must 方法需要传入QueryBuilder queryBuilder类型的参数,这个参数相当于and之后=,like等操作符
QueryBuilders.prefixQuery ,前缀匹配相当于like'%value' 比如:QueryBuilders.prefixQuery("title.keyword", value),在sql中表示就是like '%value'
QueryBuilders.termQuery 精准匹配相当于=,比如:QueryBuilders.termQuery("title.keyword", value),在sql中表示就是='value'
QueryBuilders.matchPhraseQuery 模糊匹配,但是他的算法并不是sql,like'%value%',在某些场景可能不满足需求可以使用通配符的方式平替
new WildcardQueryBuilder("title.keyword","*"+value+"*") 相当于 sql的like'%value%'
queryBuilder.should(QueryBuilders.prefixQuery( "title.keyword",value));//相当于or
builder.from(Integer.valueOf(offset)).size(limit);//限制开始位置以及长度可以用作分页
builder.trackTotalHits(true);//关闭es默认限制一万条
builder.query(boolQueryBuilder);//房子搭建完成,相当于where写完了
builder.aggregation(AggregationBuilders.terms(strField).field("title.keyword").size(100));//聚合操作,相当于order by
builder.sort("title.keyword", strSortWay == 0 ? SortOrder.ASC : SortOrder.DESC);//排序,可降序还是升序
SearchResponse search = esTemplate.search("indexName", builder); //相当于执行sql indexName是es的索引名称
search.getTook().getMillis()//获取执行时间
hits.getHits()//执行的结果
searchHit.getSourceAsMap()//获取返回结果的map,相当于sql查询返回的字段
searchHit.getSortValues() //获取排序值
search.getAggregations() //获取聚合的值
重点:如何像sql一样写 and (xxx=xxx or xxx=xxx)的多字段拼接sql
答:再加一个BoolQueryBuilder,用BoolQueryBuilder包一个BoolQueryBuilder
boolQueryBuilder.must(BoolQueryBuilder);
注:此方式是低版本的查询方式,高版本的API采用异步回调的方式,此处提供理念