使用SpringBoot集成Elasticsearch实现CRUD功能
创始人
2025-01-10 05:36:00
0

添加Elasticsearch依赖

首先,在pom.xml文件中添加Spring Boot和Elasticsearch的依赖:

      org.springframework.boot     spring-boot-starter-data-elasticsearch         org.elasticsearch.client     elasticsearch-rest-high-level-client     7.16.0   

配置Elasticsearch连接信息

application.propertiesapplication.yml文件中配置Elasticsearch连接信息:

使用application.properties配置:

# Elasticsearch properties spring.elasticsearch.rest.uris=http://localhost:9200

使用application.yml配置:

spring:   elasticsearch:     rest:       uris: http://localhost:9200 

定义实体类

定义一个简单的实体类,作为索引中的文档:

import org.springframework.data.annotation.Id; import org.springframework.data.elasticsearch.annotations.Document;  @Document(indexName = "books", createIndex = true) public class Book {      @Id     private String id;      private String title;      private String author;      // 省略构造函数、getter和setter } 

创建Elasticsearch操作接口

创建一个接口来定义对Elasticsearch的操作:

import org.springframework.data.elasticsearch.annotations.Query; import org.springframework.data.elasticsearch.repository.ElasticsearchRepository; import java.util.List;  public interface BookRepository extends ElasticsearchRepository {      List findByTitle(String title);      @Query("{\"match\": {\"author\": \"?0\"}}")     List findByAuthorQuery(String author); } 

实现CRUD操作

在服务类或控制器中使用BookRepository进行CRUD操作:

import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*;  @RestController @RequestMapping("/books") public class BookController {      @Autowired     private BookRepository bookRepository;      @PostMapping     public Book addBook(@RequestBody Book book) {         return bookRepository.save(book);     }      @GetMapping("/{id}")     public Book getBook(@PathVariable String id) {         return bookRepository.findById(id).orElse(null);     }      @PutMapping("/{id}")     public Book updateBook(@PathVariable String id, @RequestBody Book book) {         book.setId(id); // 设置要更新的文档的ID         return bookRepository.save(book);     }      @DeleteMapping("/{id}")     public void deleteBook(@PathVariable String id) {         bookRepository.deleteById(id);     }      @GetMapping("/title/{title}")     public List findByTitle(@PathVariable String title) {         return bookRepository.findByTitle(title);     }      @GetMapping("/author/{author}")     public List findByAuthor(@PathVariable String author) {         return bookRepository.findByAuthorQuery(author);     } } 

示例说明

  • Book:使用@Document注解指定了索引名称和是否自动创建索引。
  • BookRepository接口:继承自ElasticsearchRepository,定义了一些基本的查询方法和自定义的查询方法。
  • BookController:使用BookRepository进行CRUD操作的示例控制器,包括添加、获取、更新和删除文档,以及根据标题和作者进行查询。

注意事项

  • 确保Elasticsearch服务器已经启动,并且配置信息(如端口、主机)正确匹配。
  • 在实际项目中,你可能需要根据具体的业务需求,定义更多的查询方法或者对查询结果进行处理。
  • 需要根据你的Elasticsearch版本来选择合适的elasticsearch-rest-high-level-client版本,并进行相应的依赖管理。

通过这些步骤,你可以在Spring Boot应用程序中轻松地集成Elasticsearch,并实现对其的CRUD操作。

相关内容

热门资讯

黑科技辅助(微扑克ai)外挂软... 黑科技辅助(微扑克ai)外挂软件透明挂智能ai代打辅助器安装(透视)新2025版(2024已更新)(...
发现一款“wepoker发牌规... 发现一款“wepoker发牌规律总结”(透视)详细开挂辅助教程wepoker透视技巧对新手有所帮助,...
黑科技辅助(线上德州)外挂软件... 黑科技辅助(线上德州)外挂软件透明挂智能ai辅助黑科技(透视)软件教程(2022已更新)(哔哩哔哩)...
查到实测辅助“HHpoker辅... 查到实测辅助“HHpoker辅助开挂教程”(透视)详细开挂辅助教程“透视”并非一种简单快速获取胜利的...
黑科技辅助(好运大菠萝)外挂软... 黑科技辅助(好运大菠萝)外挂软件透明挂智能ai代打辅助软件(透视)线上教程(2020已更新)(哔哩哔...
终于知道“WePoKer开挂辅... 终于知道“WePoKer开挂辅助软件”(透视)详细开挂辅助方法让我们明确一下“透视”的定义。在WeP...
黑科技辅助(WPK私人房)外挂... 黑科技辅助(WPK私人房)外挂软件透明挂智能ai辅助器安装(透视)爆料教程(2025已更新)(哔哩哔...
发现玩家“HHpoker开挂辅... 发现玩家“HHpoker开挂辅助”(透视)详细开挂辅助方法数据获取与处理要实现有效透视,需要收集并处...
黑科技辅助(wepoke科技)... 黑科技辅助(wepoke科技)外挂软件透明挂智能ai辅助下载(透视)科技教程(2025已更新)(哔哩...
玩家必备教程“德州传奇辅助软件... 玩家必备教程“德州传奇辅助软件下载”(透视)详细开挂辅助方法在的世界里,玩家们追求的不仅是技巧和运气...