elasticsearch多字段搜索高亮

基于springboot datda 代码如下,可直接使用

    @Resource
    private ElasticsearchOperations elasticsearchOperations;

    @GetMapping("getHighByContent")
    public List<Job> getHighByContent(String keyword) {
        if(StringUtils.isBlank(keyword)){
            return new ArrayList<>();
        }
        //根据一个值查询多个字段  并高亮显示  这里的查询是取并集,即多个字段只需要有一个keyword满足即可
        //需要查询的字段
        /**
         * must
         * 所有的语句都 必须(must) 匹配,与 AND 等价。
         * must_not
         * 所有的语句都 不能(must not) 匹配,与 NOT 等价。
         * should
         * 至少有一个语句要匹配,与 OR 等价
         */
        BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery()
                .should(QueryBuilders.matchQuery("content", keyword))
                .should(QueryBuilders.matchQuery("name", keyword));
        //构建高亮查询
        NativeSearchQuery searchQuery = new NativeSearchQueryBuilder()
                .withQuery(boolQueryBuilder)
                .withHighlightFields(
                        new HighlightBuilder.Field("content")
                        , new HighlightBuilder.Field("name"))
                .withHighlightBuilder(new HighlightBuilder().preTags("<span style='color:red'>").postTags("</span>"))
                //分页数据
                .withPageable(PageRequest.of(0, 10))
                .build();
        //查询
        SearchHits<Job> search = elasticsearchOperations.search(searchQuery, Job.class);
        //得到查询返回的内容
        List<SearchHit<Job>> searchHits = search.getSearchHits();
        //设置一个最后需要返回的实体类集合
        List<Job> jobs = new ArrayList<>();
        //遍历返回的内容进行处理
        for (SearchHit<Job> searchHit : searchHits) {
            //高亮的内容
            Map<String, List<String>> highlightFields = searchHit.getHighlightFields();
            //将高亮的内容填充到content中
            searchHit.getContent().setName(highlightFields.get("name") == null ? searchHit.getContent().getName() : highlightFields.get("name").get(0));
            searchHit.getContent().setContent(highlightFields.get("content") == null ? searchHit.getContent().getContent() : highlightFields.get("content").get(0));
            //放到实体类中
            jobs.add(searchHit.getContent());
        }
        return jobs;
    }
Spring Boot 3 + Elasticsearch 8 的组合可以用于构建一个高效的全文检索系统,特别是当涉及到动态搜索高亮显示功能时。Elasticsearch 提供了强大的搜索引擎能力,而 Spring Boot 则提供了简化配置和快速启动微服务的框架。 要实现高亮显示全文检索,你需要做以下几个步骤: 1. **整合依赖**: - 添加Spring Data Elasticsearch依赖到你的`pom.xml`或`build.gradle`文件中。 ```xml <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-elasticsearch</artifactId> <!-- 使用对应版本 --> </dependency> ``` 2. **配置Elasticsearch**: 在Spring Boot应用中,设置Elasticsearch的连接信息,包括集群地址等。 ```java @Configuration public class ElasticsearchConfig { // ...省略 @Bean public RestHighLevelClient restClient() { return new PreBuiltRestClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); } } ``` 3. **创建索引模板和映射**: 在Elasticsearch中,为文档定义一个索引模板和字段映射,以便支持高亮显示。 ```json PUT _template/my-template { "template": "my-index", "settings": { ... }, "mappings": { "properties": { "content": { "type": "text", "fields": { "raw": { "type": "keyword" }, // 存储原始文本 "highlight": { // 高亮字段 "type": "html", "fields": { "plain": { "type": "plain" } // 简单格式化的高亮 } } } } } } } ``` 4. **查询并高亮显示**: 使用Spring Data Elasticsearch的`SearchTemplate`来进行查询,并设置`Highlighter`来获取高亮结果。 ```java @Autowired private ElasticsearchOperations elasticsearchOperations; public List<MyDocument> searchAndHighlight(String query) { SearchQuery searchQuery = new NativeSearchQueryBuilder() .withQuery(QueryBuilders.matchQuery("content", query)) .highlighter(new HighlightBuilder().field("content.highlight")) .build(); NativeSearchResponse response = elasticsearchOperations.search(searchQuery, MyDocument.class); return response.getHits().map(Hit::getContent); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值