springboot集成ElasticSearch的具体操作(系统全文检索)

es搜索引擎的个人理解:将数据库中 ,在需要做全文检索的业务数据同步一份到es搜索引擎里面,建立在同一个索引下的数据集。

1.项目引入maven依赖

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

2.建立es与数据库数据的实体类

package com.test.model;


import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;
import org.springframework.data.elasticsearch.annotations.FieldType;

import java.util.Date;

/**
 * Es 索引库实体
 *
 * @author wangwei
 * @date 2023-07-31
 */
@Document(indexName = "rabbit1")
@Data
public class EsModel {

    /*** 索引id*/
    @Field(type = FieldType.Long)
    private Long id;

    /**** es中对应的数据库业务单据id*/
    @Field(analyzer = "ik_max_word")
    private Long ctId;

    /**** es中业务数据 对应的业务数据库表名称*/
    @Field(analyzer = "ik_max_word")
    private String ctTableName;

    /**** es中业务数据 对应的 业务简称*/
    @Field(analyzer = "ik_max_word")
    private String ctName;


    /**** es中业务数据 对应的 业务内容详细信息*/
    @Field(analyzer = "ik_max_word")
    private String ctContent;


    /** 备注 */
    @Field(analyzer = "ik_max_word")
    private String remark;

    /** 备用1 */
    @Field(analyzer = "ik_max_word")
    private String by1;

    /** 备用2 */
    @Field(analyzer = "ik_max_word")
    private String by2;

    /** 备用3 */
    @Field(analyzer = "ik_max_word")
    private String by3;

    /** 备用4 */
    @Field(analyzer = "ik_max_word")
    private String by4;

    /** 备用5 */
    @Field(analyzer = "ik_max_word")
    private String by5;

}

3.建立es操作接口

package com.test.repository;

import com.test.model.EsModel;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;
import org.springframework.stereotype.Repository;

/**
 * @author wangwei
 * @date 2023-07-31 14:12:36
 */
@Repository
public interface EsRepository extends ElasticsearchRepository<EsModel, String> {


    /****
     * 删除es操作
     */
    public void deleteById(Long id);


}

4.具体业务使用

package com.test.business.service.impl;
import java.io.IOException;
import java.util.List;
import com.alibaba.fastjson.JSON;
import com.test.business.domain.*;
import com.test.business.domain.dto.TbAjkDto;
import com.test.business.domain.dto.TbAjkExportDto;
import com.test.business.mapper.*;
import com.test.common.exception.CustomException;
import com.test.constant.EsConstants;
import com.test.model.EsModel;
import com.test.model.TbAjkEs;
import com.test.model.TbAjkEsRepository;
import com.test.repository.EsRepository;
import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.action.update.UpdateResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.xcontent.XContentType;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.stereotype.Service;
import com.test.business.service.ITbAjkService;
import org.springframework.transaction.annotation.Transactional;

/**
 * 库详情Service业务层处理
 *
 * @author wangwei
 * @date 2023-07-18
 */
@Service
public class TbAjkServiceImpl implements ITbAjkService {
    @Autowired
    private TbAjkMapper tbAjkMapper;
    @Autowired
    private TbAjgjcMapper tbAjgjcMapper;
    @Autowired
    private TbAjxyrMapper tbAjxyrMapper;
    @Autowired
    private TbAjxxlMapper tbAjxxlMapper;
    @Autowired
    private TbAjwllMapper tbAjwllMapper;
    @Autowired
    private TbAjzjlMapper tbAjzjlMapper;
    @Autowired
    private TbAjtxlMapper tbAjtxlMapper;
    @Autowired
    private PublicSqlMapper publicSqlMapper;
    @Autowired
    private TbAjkEsRepository tbAjkEsRepository;
    @Autowired
    private EsRepository esRepository;
    @Autowired
    private RestHighLevelClient client;


    /**
     * 查询库详情
     *
     * @param id 详情主键
     * @return 库详情
     */
    @Override
    public TbAjk selectTbAjkById(Long id) {
        return tbAjkMapper.selectTbAjkByCtId(id);
    }

    /**
     * 查询详情列表
     *
     * @param 库详情
     * @return 库详情
     */
    @Override
    public List<TbAjk> selectTbAjkList(TbAjk tbAjk) {
        return tbAjkMapper.selectTbAjkList(tbAjk);
    }

    /**
     * 新增库详情
     * 新增es中的信息
     *
     * @param tbAjk 详情
     * @return 结果
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public int insertTbAjk(TbAjk tbAjk) {
        int i = tbAjkMapper.insertTbAjk(tbAjk);
        if (i == 1) {
            EsModel esModel = new EsModel();
            Integer integer = publicSqlMapper.selectInsertId();
            esModel.setId(Long.valueOf(integer));
            esModel.setCtId(Long.valueOf(integer));
            esModel.setCtTableName("tb_ajk");
            esModel.setCtName(tbAjk.getAjmc());
            esModel.setCtContent(tbAjk.getCjsy());//处事由
            esModel.setBy1(tbAjk.getLaay());//案由
            esModel.setBy2(tbAjk.getAjlb());//类别
            esModel.setBy3(tbAjk.getCjnr());//内容
            esModel.setBy4(tbAjk.getContent());//出内容
            esModel.setBy5(tbAjk.getCbpcs());//承办
            esModel.setRemark(tbAjk.getJyaq());//简要情
            try {
                esRepository.save(esModel);
            } catch (Exception e) {
                throw new CustomException("ES数据同步失败,请联系管理员处理!");
            }
        } else {
            throw new CustomException("数据库操作失败,请联系管理员处理!");
        }
        return 1;
    }

    /**
     * 修改库详情
     * 修改es中的信息
     * es: 1. 查询es中的数据
     * es: 2. 修改es中的数据
     *
     * @param 库详情
     * @return 结果
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public int updateTbAjk(TbAjk tbAjk) {
        int i = tbAjkMapper.updateTbAjk(tbAjk);
        if (i == 1) {
            // public UpdateRequest(String index, String type, String id) {
            //  es-update  https://www.jb51.net/article/246798.htm
            UpdateRequest updateRequest = new UpdateRequest(EsConstants.ES_INDEX, EsConstants.ES_INDEX_TYPE, String.valueOf(tbAjk.getCtId()));
            EsModel esModel = new EsModel();
            esModel.setId(Long.valueOf(tbAjk.getCtId()));
            esModel.setCtId(Long.valueOf(tbAjk.getCtId()));
            esModel.setCtName(tbAjk.getAjmc());
            esModel.setCtContent(tbAjk.getCjsy());//事由
            esModel.setBy1(tbAjk.getLaay());//案由
            esModel.setBy2(tbAjk.getAjlb());//类别
            esModel.setBy3(tbAjk.getCjnr());//内容
            esModel.setBy4(tbAjk.getContent());//出内容
            esModel.setBy5(tbAjk.getCbpcs());//承办
            esModel.setRemark(tbAjk.getJyaq());//简要情
            //更新    将对象转换为json
            updateRequest.doc(JSON.toJSONString(esModel), XContentType.JSON);
            //客户端发送请求,进行更新
            UpdateResponse update = null;
            try {
                update = client.update(updateRequest, RequestOptions.DEFAULT);
            } catch (IOException e) {
                throw new CustomException("ES数据同步失败可能原因是es中的业务ctId在数据库中不存在,请查看es客户端查询验证,请联系管理员处理!");
            }

            if (!"OK".equals(update.status().toString())) {
                throw new CustomException("ES数据同步失败,请联系管理员处理!");
            }
        } else {
            throw new CustomException("数据库操作失败,请联系管理员处理!");
        }
        return 1;
    }

    /**
     * 批量删除库详情
     *
     * @param ids 需要删除的详情主键
     * @return 结果
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public int deleteTbAjkByIds(Long[] ids) {
        int i = tbAjkMapper.deleteTbAjkByCtIds(ids);
        if (i != 1) {
            throw new CustomException("数据库操作失败,请联系管理员处理!");
        }
        for (int ii = 0; ii < ids.length; ii++) {
            try {
                esRepository.deleteById(ids[ii]);
            } catch (Exception e) {
                throw new CustomException("ES同步数据失败,请联系管理员处理!");
            }
        }
        return 1;
    }

    /**
     * 删除详情信息
     *
     * @param id 详情主键
     * @return 结果
     */
    @Transactional(rollbackFor = Exception.class)
    @Override
    public int deleteTbAjkById(Long id) {
        int i = tbAjkMapper.deleteTbAjkByCtId(id);
        if (i != 1) {
            throw new CustomException("数据库操作失败,请联系管理员处理!");
        }
        try {
            esRepository.deleteById(id);
        } catch (Exception e) {
            throw new CustomException("ES同步数据失败,请联系管理员处理!");
        }
        return 1;
    }
}

5.es查询说明

5.1 es案字段key查询

    @Override
    public AjaxResult searchES(String key) {
        Pageable pageable = null;
        Page<TbAjkEs> byAjmc = tbAjkEsRepository.findByAjmc(key, pageable);
        return AjaxResult.success(byAjmc);
    }

5.2 全文检索(高阶用法)

说明:按业务需要在withQuery(matchQuery("", key))中天剑需要检索的字段键值,进行全文检索

/***
     * //全文检索
     * @param key
     * @return
     */
    @Override
    public AjaxResult searchWhole(String key) {
        Pageable pageable = null;

        if (StringUtils.isEmpty(key)) {
            System.out.println("key is null");
        }
        //全文检索
        SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();

        SearchQuery searchQuery = new NativeSearchQueryBuilder()
                .withQuery(matchQuery("ctName", key))
                .withQuery(matchQuery("ctContent", key))
                .withQuery(matchQuery("remark", key))
               // .withPageable(pageable)
                .build();

        Page<EsModel> esModels = elasticsearchRestTemplate.queryForPage(searchQuery, EsModel.class);
        return AjaxResult.success(esModels);
    }

6.es客户端查看数据的操作

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Spring Boot是一个基于Java的开源框架,用于快速构建独立的、生产级别的应用程序。它简化了Spring框架的开发过程,提供了大量的默认配置,开发者只需关注业务逻辑的实现即可。 Elasticsearch是一个开源的分布式搜索和分析引擎,它使用倒排索引的方式进行高效的文本搜索。它提供了丰富、强大的查询语言和API,可以帮助我们构建高性能、可扩展的搜索应用。 要构建一个博客检索系统,可以使用Spring BootElasticsearch的组合。首先,我们可以使用Spring Boot搭建一个简单的web应用,用于展示博客内容和处理用户请求。Spring Boot提供了快速开发的能力,可以方便地构建页面和处理数据。 然后,我们需要将博客的内容导入到Elasticsearch中进行索引。可以编写一个程序,通过Elasticsearch提供的API将博客内容导入到索引中。这样,我们就可以通过Elasticsearch查询语言来搜索博客文章。 最后,我们可以在Spring Boot应用中编写一个搜索接口,通过接收用户的搜索关键字,调用Elasticsearch的API进行查询,并将查询结果返回给用户。用户可以根据搜索结果点击进入详细页面查看博客内容。 构建博客检索系统需要注意索引的更新问题,当博客内容发生变化时,需要及时同步到Elasticsearch的索引中,以确保数据的最新性。可以使用定时任务或者监听数据库变化的方式实现索引的更新。 总结来说,使用Spring BootElasticsearch可以快速构建一个博客检索系统Spring Boot提供了便捷的开发环境,而Elasticsearch提供了强大的搜索和分析引擎,帮助我们实现高性能的搜索功能。 ### 回答2: Spring Boot是一个用于简化Spring应用开发的框架,它通过提供默认的配置和约定来简化Java应用程序的开发过程。Elasticsearch是一个开源的分布式搜索和分析引擎,可以高效地存储、检索和分析大量结构化和非结构化数据。 通过使用Spring BootElasticsearch,我们可以构建一个免费的博客检索系统。首先,我们可以使用Spring Boot框架来开发一个简单的博客应用,在其中包括博客的标题、内容、作者和发布时间等基本信息。我们可以使用Spring Data Elasticsearch集成Elasticsearch搜索功能,并将博客的相关信息存储在Elasticsearch的索引中。 接下来,我们可以利用Elasticsearch的强大的搜索和查询功能来构建一个可靠和高效的博客检索系统。通过对博客索引进行全文搜索,用户可以根据关键词搜索博客,系统会返回与关键词相关的博客内容。 除了基本的搜索功能,我们还可以通过利用Elasticsearch的聚合功能来实现更复杂的检索需求。例如,我们可以计算某个时间段内博客的发布数量,或者根据作者分组计算每个作者的博客数量。这些聚合操作可以帮助我们快速获取博客数据的统计信息,以实现更细粒度的博客检索。 总之,利用Spring BootElasticsearch,我们可以构建一个免费的博客检索系统,提供强大的全文搜索和聚合功能,帮助用户快速找到他们感兴趣的博客内容。这个系统不仅易于开发和维护,还能够处理大量的博客数据,提供稳定和高效的检索服务。 ### 回答3: Spring Boot是一种用于快速开发Java应用程序的框架,而Elasticsearch是一个开源的分布式搜索引擎。结合两者,可以构建一个强大的博客检索系统。 首先,我们可以使用Spring Boot框架来构建博客系统后端。通过使用Spring Boot的自动配置和约定优于配置的设计原则,我们可以快速搭建一个可靠的后端应用程序。我们可以使用Spring MVC来处理前端请求,并使用Spring Data来与数据库进行交互和管理数据。通过使用Spring Security可以确保博客系统的安全性。 其次,我们需要集成Elasticsearch作为博客系统的搜索引擎。Elasticsearch是一个分布式的实时搜索和分析引擎,具有强大的全文搜索能力和高性能。我们可以通过使用Spring Data Elasticsearch模块来简化与Elasticsearch的交互,它提供了丰富的API来执行各种搜索操作。 在博客系统中,我们可以使用Elasticsearch建立博客的全文索引。当用户进行搜索时,我们可以使用Elasticsearch查询语言来执行搜索操作,并返回与查询相关的博客文章。我们可以使用Elasticsearch的分词、关键字匹配和模糊搜索等功能来提高搜索的准确性和效率。 为了提升用户体验,我们可以使用Elasticsearch的聚合功能来生成搜索建议和热门标签等。这样用户可以更方便地找到他们想要的博客内容。 综上所述,通过免费课程学习Spring BootElasticsearch,我们可以构建一个功能强大的博客检索系统。这将使用户能够轻松搜索并获取他们所需的博客文章。同时,使用Spring BootElasticsearch的优势,我们可以快速开发和部署这个系统,并保证其可靠性和性能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

王大锤4391

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

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

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

打赏作者

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

抵扣说明:

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

余额充值