【ES】JavaAPI学习-08 模糊查询 高亮查询 聚合查询 分组查询

在这里插入图片描述

前言

本节实现条件查询中的模糊查询,高亮查询, 聚合查询 分组查询

模糊查询 高亮查询

模糊查询:模糊查询允许你查找与给定术语相似但不完全匹配的文档

高亮查询:高亮查询可以突出显示匹配查询条件的部分

实现

ESTest_Doc_Cond_Query_Fuzzy.java

org.elasticsearch.index.query.QueryBuilders:提供构建各种查询条件的方法。

org.elasticsearch.common.unit.Fuzziness:定义模糊匹配的模糊程度。

构建模糊查询请求:
创建一个SearchRequest对象,指定要查询的索引为"users"。
创建一个SearchSourceBuilder对象,用于构建查询条件。
使用QueryBuilders.fuzzyQuery("name", "王五").fuzziness(Fuzziness.ONE)构建一个模糊查询条件,表示查询"name"字段包含与"王五"相似的文档,其中"Fuzziness.ONE"表示最大编辑距离为1(即最多允许有一个字符的差异)。
将模糊查询条件设置到SearchSourceBuilder对象中。
将SearchSourceBuilder对象设置到SearchRequest对象中。

package com.zwy.es;

import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.unit.Fuzziness;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.query.RangeQueryBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.builder.SearchSourceBuilder;

import java.io.IOException;

public class ESTest_Doc_Cond_Query_Fuzzy {
    public static void main(String[] args) throws IOException {

        //
        RestHighLevelClient esClient = new RestHighLevelClient(
                RestClient.builder(new HttpHost("localhost", 9200, "http"))
        );

        // 模糊查询数据
        SearchRequest request = new SearchRequest();
        request.indices("users");

        SearchSourceBuilder builer = new SearchSourceBuilder();
        builer.query(QueryBuilders.fuzzyQuery("name", "王五").fuzziness(Fuzziness.ONE));

        request.source(builer);
        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);

        SearchHits hits = response.getHits();

        System.out.println(hits.getTotalHits());  // 打印
        System.out.println(response.getTook());  // 打印

        for (SearchHit hit : hits) {
            System.out.println(hit.getSourceAsString());
        }

        // 关闭ES客户端
        esClient.close();

    }
}

ESTest_Doc_Cond_Query_Highlight.java

org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder:用于构建高亮显示规则的类。

构建查询和高亮显示请求:
创建一个SearchRequest对象,指定要查询的索引为"users"。
创建一个SearchSourceBuilder对象,用于构建查询条件和高亮显示规则。
使用QueryBuilders.termQuery("name", "张三")构建一个精确匹配查询条件,表示查询"name"字段等于"张三"的文档。
创建一个HighlightBuilder对象,用于定义高亮显示规则。
使用highlightBuilder.preTags("<font color='red'>")highlightBuilder.postTags("</font>")设置高亮标签的开始和结束标签,这里将匹配的文本用红色字体显示。
使用highlightBuilder.field("name")指定需要高亮显示的字段,这里是"name"字段。
将高亮显示规则设置到SearchSourceBuilder对象中。
将查询条件设置到SearchSourceBuilder对象中。
将SearchSourceBuilder对象设置到SearchRequest对象中。

package com.zwy.es;

import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.unit.Fuzziness;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.query.TermQueryBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;

import java.io.IOException;

public class ESTest_Doc_Cond_Query_Highlight {
    public static void main(String[] args) throws IOException {

        //
        RestHighLevelClient esClient = new RestHighLevelClient(
                RestClient.builder(new HttpHost("localhost", 9200, "http"))
        );

        // 模糊查询数据
        SearchRequest request = new SearchRequest();
        request.indices("users");

        SearchSourceBuilder builer = new SearchSourceBuilder();
        TermQueryBuilder termQueryBuilder = QueryBuilders.termQuery("name", "张三");

        HighlightBuilder highlightBuilder = new HighlightBuilder();
        highlightBuilder.preTags("<font color='red'>");
        highlightBuilder.postTags("</font>");
        highlightBuilder.field("name");

        builer.highlighter(highlightBuilder);
        builer.query(termQueryBuilder);

        request.source(builer);
        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);

        SearchHits hits = response.getHits();

        System.out.println(hits.getTotalHits());  // 打印
        System.out.println(response.getTook());  // 打印

        for (SearchHit hit : hits) {
            System.out.println(hit.getSourceAsString());
        }

        // 关闭ES客户端
        esClient.close();

    }
}


文件结构

文件结构如下:

在这里插入图片描述

运行

ESTest_Doc_Cond_Query_Fuzzy.java,结果如下:

在这里插入图片描述

成功

ESTest_Doc_Cond_Query_Highlight.java,结果如下:

在这里插入图片描述
可以看到没有命中

聚合查询 分组查询

聚合查询:聚合查询允许你对搜索结果进行统计分析。

分组查询:分组查询通常是指术语聚合,它将文档按某个字段的值进行分组

实现

聚合查询
ESTest_Doc_Cond_Query_Agg.java

org.elasticsearch.index.query.TermQueryBuilder:用于构建精确匹配查询条件的类。
org.elasticsearch.search.aggregations.AggregationBuilders:提供构建各种聚合操作的方法

构建查询和聚合请求:
创建一个SearchRequest对象,指定要查询的索引为"users"。
创建一个SearchSourceBuilder对象,用于构建查询条件和聚合操作。
使用AggregationBuilders.max("maxAge").field("age")构建一个最大值聚合操作,表示计算"name"字段等于"张三"的文档中"age"字段的最大值,并将这个聚合操作命名为"maxAge"。
将聚合操作设置到SearchSourceBuilder对象中。
SearchSourceBuilder对象设置到SearchRequest对象中。

package com.zwy.es;

import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.query.TermQueryBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.aggregations.AggregationBuilder;
import org.elasticsearch.search.aggregations.AggregationBuilders;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;

import java.io.IOException;

public class ESTest_Doc_Cond_Query_Agg {
    public static void main(String[] args) throws IOException {

        //
        RestHighLevelClient esClient = new RestHighLevelClient(
                RestClient.builder(new HttpHost("localhost", 9200, "http"))
        );

        // 聚合查询查询数据
        SearchRequest request = new SearchRequest();
        request.indices("users");

        SearchSourceBuilder builer = new SearchSourceBuilder();
        AggregationBuilder aggregationBuilder = AggregationBuilders.max("maxAge").field("age");

        builer.aggregation(aggregationBuilder);

        request.source(builer);
        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);

        SearchHits hits = response.getHits();

        System.out.println(hits.getTotalHits());  // 打印
        System.out.println(response.getTook());  // 打印

        for (SearchHit hit : hits) {
            System.out.println(hit.getSourceAsString());
        }

        // 关闭ES客户端
        esClient.close();

    }
}

分组查询
ESTest_Doc_Cond_Query_Group.java

org.elasticsearch.search.aggregations.AggregationBuilders:提供构建各种聚合操作的方法。

构建分组查询请求:
创建一个SearchRequest对象,指定要查询的索引为"users"。
创建一个SearchSourceBuilder对象,用于构建分组查询条件。
使用AggregationBuilders.terms("ageGroup").field("age")构建一个术语聚合操作,表示根据"name"字段等于"张三"的文档中"age"字段的值进行分组,并将这个聚合操作命名为"ageGroup"。
将聚合操作设置到SearchSourceBuilder对象中。
SearchSourceBuilder对象设置到SearchRequest对象中。

package com.zwy.es;

import org.apache.http.HttpHost;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.SearchHits;
import org.elasticsearch.search.aggregations.AggregationBuilder;
import org.elasticsearch.search.aggregations.AggregationBuilders;
import org.elasticsearch.search.builder.SearchSourceBuilder;

import java.io.IOException;

public class ESTest_Doc_Cond_Query_Group {
    public static void main(String[] args) throws IOException {

        //
        RestHighLevelClient esClient = new RestHighLevelClient(
                RestClient.builder(new HttpHost("localhost", 9200, "http"))
        );

        // 分组查询查询数据
        SearchRequest request = new SearchRequest();
        request.indices("users");

        SearchSourceBuilder builer = new SearchSourceBuilder();
        AggregationBuilder aggregationBuilder = AggregationBuilders.terms("ageGroup").field("age");
        builer.aggregation(aggregationBuilder);

        request.source(builer);
        SearchResponse response = esClient.search(request, RequestOptions.DEFAULT);

        SearchHits hits = response.getHits();

        System.out.println(hits.getTotalHits());  // 打印
        System.out.println(response.getTook());  // 打印

        for (SearchHit hit : hits) {
            System.out.println(hit.getSourceAsString());
        }

        // 关闭ES客户端
        esClient.close();

    }
}

文件结构

文件结构如下:

在这里插入图片描述

运行

运行ESTest_Doc_Cond_Query_Agg.java,结果如下:

在这里插入图片描述
运行ESTest_Doc_Cond_Query_Group.java,结果如下:
在这里插入图片描述

成功!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,您的问题是如何使用 Java API 获取 Elasticsearch 中的总数。 您可以使用 Elasticsearch Java API 中的 `SearchRequest` 和 `SearchResponse` 来实现。具体实现步骤如下: 1. 创建一个 `SearchRequest` 对象,并设置需要查询的 index。 ```java SearchRequest searchRequest = new SearchRequest("your_index_name"); ``` 2. 创建一个 `SearchSourceBuilder` 对象,并设置需要查询的条件。这里我们只需要查询总数,所以只需要设置一个 `size` 为 0 的参数即可。 ```java SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.size(0); ``` 3. 将 `SearchSourceBuilder` 对象设置到 `SearchRequest` 中。 ```java searchRequest.source(searchSourceBuilder); ``` 4. 执行查询,并获取查询结果中的总数。 ```java SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT); long totalHits = searchResponse.getHits().getTotalHits().value; ``` 注意:在执行查询之前,需要先创建一个 `RestHighLevelClient` 对象,并设置好连接 Elasticsearch 的参数。 完整的 Java 代码示例: ```java RestHighLevelClient restHighLevelClient = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); SearchRequest searchRequest = new SearchRequest("your_index_name"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.size(0); searchRequest.source(searchSourceBuilder); SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT); long totalHits = searchResponse.getHits().getTotalHits().value; restHighLevelClient.close(); ``` 希望这个回答能够帮助到您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

锥栗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值