• springboot整合elasticsearch


    matchAllQuery查询

    1. @BeforeEach
    2. void setUp() {
    3. this.client = new RestHighLevelClient(RestClient.builder(
    4. HttpHost.create("http://43.139.59.28:9200")
    5. ));
    6. }
    7. @AfterEach
    8. void tearDown() throws IOException {
    9. this.client.close();
    10. }
    11. @Test
    12. void testMatchAll() throws IOException {
    13. // 1.准备Request
    14. SearchRequest request = new SearchRequest("hotel");
    15. // 2.准备DSL
    16. request.source()
    17. .query(QueryBuilders.matchAllQuery());
    18. // 3.发送请求
    19. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    20. // 4.解析响应
    21. handleResponse(response);
    22. }
    23. private void handleResponse(SearchResponse response) {
    24. // 4.解析响应
    25. SearchHits searchHits = response.getHits();
    26. // 4.1.获取总条数
    27. long total = searchHits.getTotalHits().value;
    28. System.out.println("共搜索到" + total + "条数据");
    29. // 4.2.文档数组
    30. SearchHit[] hits = searchHits.getHits();
    31. // 4.3.遍历
    32. for (SearchHit hit : hits) {
    33. // 获取文档source
    34. String json = hit.getSourceAsString();
    35. // 反序列化
    36. HotelDoc hotelDoc = JSON.parseObject(json, HotelDoc.class);
    37. System.out.println("hotelDoc = " + hotelDoc);
    38. }
    39. }

    结果

    match查询

     全文检索的match和multi_match查询与match_all的API基本一致。差别是查询条件,也就是query的部分

    match  

    1. @Test
    2. void testMatch() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. request.source()
    7. .query(QueryBuilders.matchQuery("all", "百家"));
    8. // 3.发送请求
    9. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    10. // 4.解析响应
    11. handleResponse(response);
    12. }

    结果

    multi_match 

    1. @Test
    2. void testMatch() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. request.source()
    7. .query(QueryBuilders.multiMatchQuery("百家", "name","business"));
    8. // 3.发送请求
    9. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    10. // 4.解析响应
    11. handleResponse(response);
    12. }

     结果

    精确查询

    精确查询主要是两者:

    • term:词条精确匹配

    • range:范围查询

    与之前的查询相比,差异同样在查询条件,其它都一样

     term

    1. @Test
    2. void testTerm() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. request.source()
    7. .query(QueryBuilders.termQuery("city", "北京"));
    8. // 3.发送请求
    9. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    10. // 4.解析响应
    11. handleResponse(response);
    12. }

    结果

    range

    1. @Test
    2. void testTerm() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. request.source()
    7. .query(QueryBuilders.rangeQuery("price").gte(100).lte(2000));
    8. // 3.发送请求
    9. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    10. // 4.解析响应
    11. handleResponse(response);
    12. }

     结果

    布尔查询

    布尔查询是用must、must_not、filter等方式组合其它查询

    1. @Test
    2. void testBool() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. // 2.1.准备BooleanQuery
    7. BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
    8. // 2.2.添加term
    9. boolQuery.must(QueryBuilders.termQuery("city", "上海"));
    10. // 2.3.添加range
    11. boolQuery.filter(QueryBuilders.rangeQuery("price").lte(2000));
    12. request.source().query(boolQuery);
    13. // 3.发送请求
    14. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    15. // 4.解析响应
    16. handleResponse(response);
    17. }

    结果 

    排序、分页

    搜索结果的排序和分页是与query同级的参数,因此同样是使用request.source()来设置  

    1. @Test
    2. void testPageAndSort() throws IOException {
    3. // 页码,每页大小
    4. int page = 1, size = 5;
    5. // 1.准备Request
    6. SearchRequest request = new SearchRequest("hotel");
    7. // 2.准备DSL
    8. // 2.1.query
    9. request.source().query(QueryBuilders.matchAllQuery());
    10. // 2.2.排序 sort
    11. request.source().sort("price", SortOrder.ASC);
    12. // 2.3.分页 fromsize
    13. request.source().from((page - 1) * size).size(5);
    14. // 3.发送请求
    15. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    16. // 4.解析响应
    17. handleResponse(response);
    18. }

    结果

    高亮

    高亮的代码与之前代码差异较大,有两点:

    • 查询的DSL:其中除了查询条件,还需要添加高亮条件,同样是与query同级。

    • 结果解析:结果除了要解析_source文档数据,还要解析高亮结果

    1. @Test
    2. void testHighlight() throws IOException {
    3. // 1.准备Request
    4. SearchRequest request = new SearchRequest("hotel");
    5. // 2.准备DSL
    6. // 2.1.query
    7. request.source().query(QueryBuilders.matchQuery("all", "如家"));
    8. // 2.2.高亮
    9. request.source().highlighter(new HighlightBuilder().field("name").requireFieldMatch(false));
    10. // 3.发送请求
    11. SearchResponse response = client.search(request, RequestOptions.DEFAULT);
    12. // 4.解析响应
    13. handleResponse1(response);
    14. }
    15. private void handleResponse1(SearchResponse response) {
    16. // 4.解析响应
    17. SearchHits searchHits = response.getHits();
    18. // 4.1.获取总条数
    19. long total = searchHits.getTotalHits().value;
    20. System.out.println("共搜索到" + total + "条数据");
    21. // 4.2.文档数组
    22. SearchHit[] hits = searchHits.getHits();
    23. // 4.3.遍历
    24. for (SearchHit hit : hits) {
    25. // 获取文档source
    26. String json = hit.getSourceAsString();
    27. // 反序列化
    28. HotelDoc hotelDoc = JSON.parseObject(json, HotelDoc.class);
    29. // 获取高亮结果
    30. Map<String, HighlightField> highlightFields = hit.getHighlightFields();
    31. if (!CollectionUtils.isEmpty(highlightFields)) {
    32. // 根据字段名获取高亮结果
    33. HighlightField highlightField = highlightFields.get("name");
    34. if (highlightField != null) {
    35. // 获取高亮值
    36. String name = highlightField.getFragments()[0].string();
    37. // 覆盖非高亮结果
    38. hotelDoc.setName(name);
    39. }
    40. }
    41. System.out.println("hotelDoc = " + hotelDoc);
    42. }
    43. }

    结果

  • 相关阅读:
    Java中读写锁ReadWriteLock的使用案例和性能对比
    @Cacheable 注解(指定缓存位置)
    决策树笔记1
    golang性能分析pprof使用
    系统移植第5天作业
    计算机网络-传输层
    修改CentOS默认mail发件人名称
    Python实现基于交换机转发实验
    记一次http接口自动重试现象的排查
    javascript 记录
  • 原文地址:https://blog.csdn.net/qq_63431773/article/details/132661398