Spring Boot整合ElasticSearch实战 - 第511篇

历史文章(文章累计500+)

《国内最全的Spring Boot系列之一》

《国内最全的Spring Boot系列之二》

《国内最全的Spring Boot系列之三》

《国内最全的Spring Boot系列之四》

《国内最全的Spring Boot系列之五》

《国内最全的Spring Boot系列之六》

《国内最全的Spring Boot系列之七》

日赚800,利用淘宝/闲鱼进行AI音乐售卖实操 - 第506篇

如何让AI生成自己喜欢的歌曲-AI音乐创作的正确方式 - 第507篇

ES全文检索[ES系列] - 第508篇

ES 深度分页问题及针对不同需求下的解决方案[ES系列] - 第509篇

抖音主播/电商人员有福了,利用Suno创作产品宣传,让产品动起来-小米Su7 - 第510篇

最近体验了下AI生成音乐,感觉效果很不错,有兴趣的可以访问如下地址体验一下:

https://suno3.cn/#/?i=8NCBS8_WXTT

Hi,大家好,我是悟纤。我就是我,不一样的烟火。我就是我,与众不同的小苹果。

这一节来看下在SpringBoot中如何集成ElasticSearch。

一、Spring Boot整合ElasticSearch

这里有一个版本的对应情况,最好对应上会比较好,不然会出现莫名其妙的问题。

https://docs.spring.io/spring-data/elasticsearch/docs/current/reference/html/#new-features.5-1-0

​1.1 创建项目

根据相应的版本,选择相应的Spring Boot版本,这里选择的是3.1.4版本。

1.2 添加依赖

在pom.xml文件添加依赖:

<dependencies>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-web</artifactId>    </dependency>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-data-elasticsearch</artifactId>    </dependency>    <dependency>        <groupId>org.projectlombok</groupId>        <artifactId>lombok</artifactId>    </dependency>    <dependency>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-test</artifactId>        <scope>test</scope>    </dependency></dependencies>

1.3 添加配置

在配置文件application.properties中添加配置:

spring.elasticsearch.uris = http://localhost:9200spring.elasticsearch.connection-timeout = 3s

1.4 创建实体

创建实体,使用@Field注解,添加字段在ES中的类型以及使用的分词器:

@Data@AllArgsConstructor@Document(indexName = "employees")public class Employee {    @Id    private Long id;    @Field(type= FieldType.Keyword)    private String name;    private int sex;    private int age;    @Field(type= FieldType.Text,analyzer="ik_max_word")    private String address;    private String remark;}

1.5实现ElasticsearchRepository

该接口是框架封装的用于操作Elastsearch的高级接口:

@Repositorypublic interface EmployeeRepository extends ElasticsearchRepository<Employee, Long> {    List<Employee> findByName(String name);}

1.6测试

@AutowiredEmployeeRepository employeeRepository;@Testvoid test() {    Employee employee = new Employee(1L,"悟纤",1,32,"福建福州","love coding");    //插入文档    employeeRepository.save(employee);    //根据id查询    Optional<Employee> result = employeeRepository.findById(1L);    System.out.println(String.valueOf(result.get()));    //根据name查询    List<Employee> list = employeeRepository.findByName("悟纤");    System.out.println(list.get(0));}

1.7使用ElasticsearchTemplate

@Resourceprivate ElasticsearchTemplate elasticsearchTemplate;@Testpublic void testCreateIndex(){    //创建索引    IndexOperations indexOperations = elasticsearchTemplate.indexOps(IndexCoordinates.of("employee_index"));    if (indexOperations.exists()) {        System.out.println("索引已经存在");    }else {        //创建索引        indexOperations.create();    }}@Testpublic void testDeleteIndex(){    //删除索引    IndexOperations indexOperations = elasticsearchTemplate.indexOps(IndexCoordinates.of("employee_index"));    indexOperations.delete();}@Testpublic void testQueryDocument(){    NativeSearchQueryBuilder builder = new NativeSearchQueryBuilder();    //查询    //builder.withQuery(QueryBuilders.matchQuery("address","公园"));    // 设置分页信息    builder.withPageable(PageRequest.of(0, 5));    // 设置排序    //builder.withSort(SortBuilders.fieldSort("age").order(SortOrder.DESC));    SearchHits<Employee> search = elasticsearchTemplate.search(builder.build(), Employee.class);    List<SearchHit<Employee>> searchHits = search.getSearchHits();    for (SearchHit hit: searchHits){        System.out.println("返回结果:"+hit.toString());    }}@Testpublic void testInsertBatch() throws JsonProcessingException {    List<Employee> employees = new ArrayList<>();    employees.add(new Employee(2l,"张三",1,25,"广州天河公园","java developer"));    employees.add(new Employee(3l,"李四",1,28,"广州荔湾大厦","java assistant"));    employees.add(new Employee(4l,"小红",0,26,"广州白云山公园","php developer"));    List<IndexQuery> queries = new ArrayList<>();    for (Employee employee : employees) {        IndexQuery indexQuery = new IndexQuery();        indexQuery.setId(employee.getId().toString());        ObjectMapper mapper = new ObjectMapper();        String json = mapper.writeValueAsString(employee);        indexQuery.setSource(json);        queries.add(indexQuery);    }    //bulk批量插入    elasticsearchTemplate.bulkIndex(queries,Employee.class);}

基本的集成用起来害死很简单的,关键在如何在实际的项目中进行合理的使用,这个是需要在具体的实战中进行自我摸索和探究的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/695667.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

抱怨无用,行动破局

故事的开始 这个专栏&#xff0c;以及本文的目的&#xff0c;是为了记录我从创立盘多啦这个平台开始&#xff0c;到后续的发展历程的专栏。同时也是给自己一个坚持的动力和警醒的作用。 首先&#xff0c;我是一名程序员&#xff0c;并且对于自身感兴趣的东西&#xff0c;都有…

算法学习笔记(3)-差分

#差分 差分和前缀和互为逆运算&#xff1a; 给定一个原数组s&#xff0c;差分数组h&#xff0c;两者的关系如下所示&#xff1a; s[i] h[1] h[2] h[3] …… h[i] 针对于上面的公式&#xff0c;由差分数组h推导而来 h[1] s[1] h[2] s[2] - s[1] h[3] s[3] - [2] …… h[…

什么是 RAG,大模型微调,向量数据库的应用场景

原来向量数据库的应用场景是这样的&#xff01;按照我的理解&#xff0c;大模型其实是没有学习能力的&#xff0c;它就相当于一个真值表或者矩阵&#xff0c;给它输入&#xff0c;它就输出&#xff0c;在使用它的过程中它不会自己训练自己&#xff0c;改变既有的参数&#xff0…

【深度学习】实验3 特征处理

特征处理 python 版本 3.7 scikit-learn 版本 1.0.2 1.标准化 from sklearn.preprocessing import StandardScaler from sklearn.preprocessing import MinMaxScaler from matplotlib import gridspec import numpy as np import matplotlib.pyplot as plt cps np.random.…

开源免费的定时任务管理系统:Gocron

Gocron&#xff1a;精准调度未来&#xff0c;你的全能定时任务管理工具&#xff01;- 精选真开源&#xff0c;释放新价值。 概览 Gocron是github上一个开源免费的定时任务管理系统。它使用Go语言开发&#xff0c;是一个轻量级定时任务集中调度和管理系统&#xff0c;用于替代L…

免费获取SSL证书的几种方法

免费获取SSL证书的方法有很多种&#xff0c;以下是一些常见的途径&#xff1a; 1、Lets Encrypt&#xff1a;Lets Encrypt是一个由非营利组织提供的免费SSL证书服务&#xff0c;其安装部署简单、方便&#xff0c;且已被Firefox、Chrome、IE等浏览器所支持。您可以通过其官方网…

C++入门——引用(2)

前言 上一节我们开始学习了C&#xff0c;并且对C有了初步的了解&#xff0c;这一节我们继续学习C的基础&#xff0c;那么废话不多说&#xff0c;我们正式进入今天的学习 C中的引用 1.1引用的概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0…

【Ubuntu永久授权串口设备读取权限“/dev/ttyUSB0”】

Ubuntu永久授权串口设备读取权限 1 问题描述2 解决方案2.1 查看ttyUSB0权限&#xff0c;拥有者是root&#xff0c;所属用户组为dialout2.2 查看dialout用户组成员&#xff0c;如图所示&#xff0c;普通用户y不在dialout组中2.3 将普通用户y加入dialout组中2.4 再次查看dialout用…

pycharm虚拟环境

File->setting->project->Python interpreter 路径必须写全

视频剪辑批量转码技巧:如何将MP4视频快速转换为MP3音频的方法

在视频剪辑和音频处理的领域中&#xff0c;经常需要将视频文件转换为音频文件&#xff0c;特别是将MP4视频转换为MP3音频。这样的转换不仅可以减少文件大小&#xff0c;方便传输和存储&#xff0c;还可以在不损失音频质量的情况下&#xff0c;方便在各种设备上播放。下面&#…

从XML配置角度理解Spring AOP

1. Spring AOP与动态代理 1.1 Spring AOP和动态代理的关系 Spring AOP使用动态代理作为其主要机制来实现面向切面的编程。这种机制允许Spring在运行时动态地创建代理对象&#xff0c;这些代理对象包装了目标对象&#xff08;即业务组件&#xff09;&#xff0c;以便在调用目标对…

使用gRPC基于Protobuf传输大文件或数据流

文章目录 使用gRPC基于Protobuf传输大文件或数据流1. 背景和技术选择1.1 gRPC的优势1.2 Protocol Buffers的优势 2. 项目配置与环境搭建2.1 安装gRPC和Protocol Buffers2.1.1 安装Cmake2.1.2 设置环境变量2.1.3 安装必要的依赖2.1.4 下载gRPC源码2.1.5 编译gRPC和 [Protocol Bu…