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

本文涉及的产品
Elasticsearch Serverless通用抵扣包,测试体验金 200元
简介: 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 {
/****
 * 删除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 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客户端查看数据的操作
image.png

image.png
image.png
image.png

相关实践学习
以电商场景为例搭建AI语义搜索应用
本实验旨在通过阿里云Elasticsearch结合阿里云搜索开发工作台AI模型服务,构建一个高效、精准的语义搜索系统,模拟电商场景,深入理解AI搜索技术原理并掌握其实现过程。
ElasticSearch 最新快速入门教程
本课程由千锋教育提供。全文搜索的需求非常大。而开源的解决办法Elasricsearch(Elastic)就是一个非常好的工具。目前是全文搜索引擎的首选。本系列教程由浅入深讲解了在CentOS7系统下如何搭建ElasticSearch,如何使用Kibana实现各种方式的搜索并详细分析了搜索的原理,最后讲解了在Java应用中如何集成ElasticSearch并实现搜索。 &nbsp;
相关文章
|
3月前
|
JavaScript 前端开发 Java
垃圾分类管理系统基于 Spring Boot Vue 3 微服务架构实操指南
本文介绍了基于Java技术的垃圾分类管理系统开发方案与实施案例。系统采用前后端分离架构,后端使用Spring Boot框架搭配MySQL数据库,前端可选择Vue.js或Java Swing实现。核心功能模块包括垃圾分类查询、科普教育、回收预约等。文中提供了两个典型应用案例:彭湖花园小区使用的Swing桌面系统和基于Spring Boot+Vue的城市管理系统,分别满足不同场景需求。最新技术方案升级为微服务架构,整合Spring Cloud、Redis、Elasticsearch等技术,并采用Docker容器
191 0
|
4月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
422 1
|
5月前
|
前端开发 Java 关系型数据库
基于Java+Springboot+Vue开发的鲜花商城管理系统源码+运行
基于Java+Springboot+Vue开发的鲜花商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的鲜花商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。技术学习共同进步
411 7
|
5月前
|
存储 Java 数据库
Spring Boot 注册登录系统:问题总结与优化实践
在Spring Boot开发中,注册登录模块常面临数据库设计、密码加密、权限配置及用户体验等问题。本文以便利店销售系统为例,详细解析四大类问题:数据库字段约束(如默认值缺失)、密码加密(明文存储风险)、Spring Security配置(路径权限不当)以及表单交互(数据丢失与提示不足)。通过优化数据库结构、引入BCrypt加密、完善安全配置和改进用户交互,提供了一套全面的解决方案,助力开发者构建更 robust 的系统。
163 0
|
2月前
|
前端开发 Java API
酒店管理系统基于 JavaFX Spring Boot 和 React 经典项目重构实操
本文介绍了基于现代技术栈的酒店管理系统开发方案,整合了JavaFX、Spring Boot和React三大技术框架。系统采用前后端分离架构,JavaFX构建桌面客户端,React开发Web管理界面,Spring Boot提供RESTful API后端服务。核心功能模块包括客房管理和客户预订流程,文中提供了JavaFX实现的客房管理界面代码示例和React开发的预订组件代码,展示了如何实现客房信息展示、添加修改操作以及在线预订功能。
160 1
|
消息中间件 存储 Java
📨 Spring Boot 3 整合 MQ 构建聊天消息存储系统
本文详细介绍了如何使用Spring Boot 3结合RabbitMQ构建高效可靠的聊天消息存储系统。通过引入消息队列,实现了聊天功能与消息存储的解耦,解决了高并发场景下直接写入数据库带来的性能瓶颈问题。文章首先分析了不同MQ产品的特点及适用场景,最终选择RabbitMQ作为解决方案,因其成熟稳定、灵活路由和易于集成等优势。接着,通过Docker快速部署RabbitMQ,并完成Spring Boot项目的配置与代码实现,包括生产者发送消息、消费者接收并处理消息等功能。最后,通过异步存储机制,既保证了消息的即时性,又实现了可靠持久化。
361 0
📨 Spring Boot 3 整合 MQ 构建聊天消息存储系统
|
4月前
|
供应链 JavaScript BI
ERP系统源码,基于SpringBoot+Vue+ElementUI+UniAPP开发
这是一款专为小微企业打造的 SaaS ERP 管理系统,基于 SpringBoot+Vue+ElementUI+UniAPP 技术栈开发,帮助企业轻松上云。系统覆盖进销存、采购、销售、生产、财务、品质、OA 办公及 CRM 等核心功能,业务流程清晰且操作简便。支持二次开发与商用,提供自定义界面、审批流配置及灵活报表设计,助力企业高效管理与数字化转型。
428 2
ERP系统源码,基于SpringBoot+Vue+ElementUI+UniAPP开发
|
3月前
|
Java 调度 流计算
基于Java 17 + Spring Boot 3.2 + Flink 1.18的智慧实验室管理系统核心代码
这是一套基于Java 17、Spring Boot 3.2和Flink 1.18开发的智慧实验室管理系统核心代码。系统涵盖多协议设备接入(支持OPC UA、MQTT等12种工业协议)、实时异常检测(Flink流处理引擎实现设备状态监控)、强化学习调度(Q-Learning算法优化资源分配)、三维可视化(JavaFX与WebGL渲染实验室空间)、微服务架构(Spring Cloud构建分布式体系)及数据湖建设(Spark构建实验室数据仓库)。实际应用中,该系统显著提升了设备调度效率(响应时间从46分钟降至9秒)、设备利用率(从41%提升至89%),并大幅减少实验准备时间和维护成本。
250 0
|
3月前
|
机器学习/深度学习 数据采集 人机交互
springboot+redis互联网医院智能导诊系统源码,基于医疗大模型、知识图谱、人机交互方式实现
智能导诊系统基于医疗大模型、知识图谱与人机交互技术,解决患者“知症不知病”“挂错号”等问题。通过多模态交互(语音、文字、图片等)收集病情信息,结合医学知识图谱和深度推理,实现精准的科室推荐和分级诊疗引导。系统支持基于规则模板和数据模型两种开发原理:前者依赖人工设定症状-科室规则,后者通过机器学习或深度学习分析问诊数据。其特点包括快速病情收集、智能病症关联推理、最佳就医推荐、分级导流以及与院内平台联动,提升患者就诊效率和服务体验。技术架构采用 SpringBoot+Redis+MyBatis Plus+MySQL+RocketMQ,确保高效稳定运行。
236 0
|
4月前
|
JSON 安全 数据可视化
Elasticsearch(es)在Windows系统上的安装与部署(含Kibana)
Kibana 是 Elastic Stack(原 ELK Stack)中的核心数据可视化工具,主要与 Elasticsearch 配合使用,提供强大的数据探索、分析和展示功能。elasticsearch安装在windows上一般是zip文件,解压到对应目录。文件,elasticsearch8.x以上版本是自动开启安全认证的。kibana安装在windows上一般是zip文件,解压到对应目录。elasticsearch的默认端口是9200,访问。默认用户是elastic,密码需要重置。
1865 0