Springboot ElasticSearch6.X 关键词高亮查询

本文介绍了如何在Springboot项目中集成Elasticsearch进行高亮查询。首先,提到了Elasticsearch的安装。接着,通过引入相关依赖、配置属性、创建实体和操作仓库,逐步展示集成步骤。在遇到高亮查询失败的问题后,通过自定义ResultMapper解决了这个问题,使得查询结果包含高亮标签。最后,展示了成功实现高亮查询的效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景:
SpringBoot       2.0.6RELEASE
ElasticSearch    6.X

如果你还没有安装Elasticsearch,希望这边文章能帮助到你

使用Docker Compose服务编排创建ELKicon-default.png?t=M1L8https://blog.youkuaiyun.com/qq_35715202/article/details/123137911


废话不多说直接上代码

1、引入pom依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>

2、属性配置

spring:
  data:
    elasticsearch:
      cluster-name: docker-cluster      #默认的是elasticsearch,注意了
      cluster-nodes: 192.168.5.28:9300  #老哥,写你自己的
      repositories:
        enabled: true

3、创建实体

import lombok.Data;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;

/**
 * @Author xiewenlong
 * @Date 2019/5/21
 */
@Data
@Document(indexName = TaskLog.INDEX_NAME, type = TaskLog.TYPE)
public class TaskLog {
    public static final String INDEX_NAME = "log";
    public static final String TYPE = "task";

    @Id
    private String id;
    @Field(type = FieldType.Text, searchAnalyzer = "ik_smart", analyzer = "ik_smart")
    private String type;
    @Field(type = FieldType.Text, searchAnalyzer = "ik_smart", analyzer = "ik_smart")
    private String name;
    private String author;
    private Integer order;
}

注意:@Id 使用实体保存后id会回显

4、创建操作仓库

package com.define.commons.admin.repository;

import com.define.commons.admin.domain.TaskLog;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
import org.springframework.stereotype.Component;

/**
 * 关键字        方法命名
 * And          findByNameAndPwd
 * Or           findByNameOrSex
 * Is           findById
 * Between      findByIdBetween
 * Like         findByNameLike
 * NotLike      findByNameNotLike
 * OrderBy      findByIdOrderByXDesc
 * Not          findByNameNot
 *
 * 自动生成实现类
 *
 * @Author xiewenlong
 * @Date 2019/5/21
 */
@Component
public interface TaskLogESRepository extends ElasticsearchRepository<TaskLog, String> {

    Page<TaskLog> findByTypeLike(String type, Pageable pageable);

}

注意:这里定义接口名称会自动生成实现类,接口命名规则改上面代码注释

5、高亮查询(失败了,先别急着开始cv大法

public class ESTest {

    private Consumer<Object> out = System.out::println;
    @Autowired
    private TaskLogESRepository taskLogESRepository;

    @Test
    public void highlight(){
        out.accept("----------------------- highlight start -----------------------");
        NativeSearchQueryBuilder queryBuilder = new NativeSearchQueryBuilder();
        //高亮
        HighlightBuilder.Field highlightField = new HighlightBuilder.Field("name")
                .preTags("<span style='color: red'>")
                .postTags("</span>");
        //条件
        queryBuilder.withQuery(QueryBuilders.matchQuery("name", "用户数据"));
        /
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Long丶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值