Springboot - ElasticSearch 查询总结

4 篇文章 0 订阅
1 篇文章 0 订阅

官方文档:
https://www.elastic.co/guide/cn/elasticsearch/guide/current/full-body-search.html

pom文件:
<!-- elasticsearch -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
 

elasticsearchTemplate:
BoolQueryBuilder 当多条件查询的时候可以用它来做拼接,它的should和must相当于mysql中的or和and
 
termQueryBuilder 有参构造的参数一:字段名,参数二:值查询,表示查询满足该字段的值的文档
 
MatchQueryBuilder 有参构造的参数一:字段名,参数二:将用户输入的关键字进行分词然后再去查询


1、termQuery对象进行字符的精确匹配查询
es的termQuery对象构造查询语句,精确查询 type= “bird” 的鸟类信息

QueryBuilders.termQuery("type", "bird");
相当于sql语句:

select * from biological where type = 'bird';
 

2、boolQuery查询
构造boolQuery的对象,在boolQuery对象里面添加逻辑判断条件。

boolquery嵌套的条件有以下类型:

(1) must: 条件必须满足,相当于 and   

(2) should: 条件可以满足也可以不满足,相当于 or

(3) must_not: 条件不需要满足,相当于 not

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
boolQuery.should(QueryBuilders.termQuery("type", "bird"));
boolQuery.should(QueryBuilders.termQuery("type", "plant"));
boolQuery.must(QueryBuilders.termQuery("name", "demo"));
相当于sql语句:

select * from biological where (type = 'bird' OR type = 'plant') AND (name = 'demo');
wildcardQuery 相当于 like

boolQuery.must(QueryBuilders.wildcardQuery("scientificname",searchMessage+"*"));
 

3、嵌套查询
sql语句:

select * from biological where (type = 'bird' AND name = 'test') OR (name = 'demo');
BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
boolQuery.should(
    boolQuery.must.QueryBuilders.termQuery("type", "bird")
             .must.QueryBuilders.termQuery("name", "test"));
boolQuery.should(QueryBuilders.termQuery("name", "demo"));
 

4、matchQuery用于文本类型字段的搜索
matchQuery会将搜索条件按照标准分词器的规则分词,分完词之后分别搜索匹配项。

public Page<NameDataList> NameDataList(String typeId, String searchMessage, int offset, HttpServletRequest request) {
        TaxondataQuery query = new TaxondataQuery();
        
        query.setPage(offset/10);
        query.setQueryString(searchMessage);
 
        // 复合查询
        BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
        boolQuery.must(QueryBuilders.termQuery("type", typeId));
        //boolQuery.filter(QueryBuilders.rangeQuery("pageSize"));
 
        // 以下为查询条件, 使用 must query 进行查询组合
        MultiMatchQueryBuilder matchQuery = QueryBuilders.multiMatchQuery(query.getQueryString(), "scientificname",
                "chinesename");
        boolQuery.must(matchQuery);
 
        PageRequest pageRequest = PageRequest.of(query.getPage(), query.getSize());
 
        NativeSearchQuery searchQuery = new NativeSearchQueryBuilder().withQuery(boolQuery)
                .withHighlightFields(
                        new HighlightBuilder.Field("scientificname"),
                        new HighlightBuilder.Field("chinesename"))
                .withPageable(pageRequest).build();
        Page<NameDataList> NameDataLists = elasticsearchTemplate.queryForPage(searchQuery, NameDataList.class, extResultMapper);
 
        return NameDataLists;
}
 

5、query与filter
query 四种子句:must,filter,should,mustNot

BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
        boolQuery.must(QueryBuilders.termQuery("chinesename", "云雀"));
        SearchQuery searchQuery = new NativeSearchQueryBuilder()
                .withQuery(boolQuery)  
                .build();
List<NameDataList> NameDataLists = elasticsearchTemplate.queryForList(searchQuery, NameDataList.class);
System.out.println(NameDataLists.toString());
filter比query快:

query的时候,会先比较查询条件,然后计算分值,最后返回文档结果;
而filter则是先判断是否满足查询条件,如果不满足,会缓存查询过程(记录该文档不满足结果);
满足的话,就直接缓存结果
综上所述,filter快在两个方面:
    1.对结果进行缓存
    2.避免计算分值
 
 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中集成Elasticsearch时,需要进行mapping配置。根据引用\[2\]中的代码示例,可以创建一个名为EsGoodsRepository的接口,并继承ElasticsearchRepository。在该接口中,可以定义对应的实体类和主键类型。这样就可以通过该接口来进行Elasticsearch的操作了。 另外,根据引用\[1\]中的说明,为了允许外部访问Elasticsearch,需要修改配置文件。配置文件的路径在config/elasticsearch.yml。可以使用vi命令打开该文件进行修改。 总结起来,集成Elasticsearch时,需要创建EsGoodsRepository接口,并继承ElasticsearchRepository,同时进行mapping配置。另外,还需要修改Elasticsearch的配置文件以允许外部访问。 #### 引用[.reference_title] - *1* *3* [SpringBoot集成Elasticsearch7.4 实战(一)](https://blog.csdn.net/qq_37284798/article/details/128718272)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [SpringBoot集成elasticsearch使用(增删改查)](https://blog.csdn.net/ljfgyy0205/article/details/130086495)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值