SpringBoot整合ElasticSearch(最新版迅速入门)

前言

这里默认读者已经安装好ElasticSearch,因为本文不会涉及到ElasticSearch的安装
在整合SpringBoot之前,需要先确定版本,以下是版本对应表(摘自官方

在这里插入图片描述

导入依赖

我这里使用的是最新的版本

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.7.2</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

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

yml配置

spring:
  elasticsearch:
    uris: 43.142.61.XXX:9200	#最新的版本只需要这样配置就可以连接上es

实体类

package com.th.elasticsearch.pojo;

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;

@Data
@Document(indexName = "user")	//user是索引的名称
public class User {
    @Id
    private int id;

    @Field(type = FieldType.Keyword)
    private String name;

    @Field(type = FieldType.Keyword)
    private int age;

    @Field(type = FieldType.Boolean)
    private boolean sex;
}

mapper

在Spring中,操作es像操作数据库一样

package com.th.elasticsearch.mapper;

import com.th.elasticsearch.pojo.User;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

import java.util.List;

public interface UserMapper extends ElasticsearchRepository<User, Integer> {
    //自定义查询方法
    List<User> findAllByNameAndAge(String name,Integer age);
}

自定义查询方法的方法名有一套自己的规则,与Spring Data JPA类似,下面是一部分规则,更多的规则可到官网进行查询

KeywordSampleElasticsearch Query String
AndfindByNameAndPrice{“bool” : {“must” : [ {“field” : {“name” : “?”}}, {“field” : {“price” : “?”}} ]}}
OrfindByNameOrPrice{“bool” : {“should” : [ {“field” : {“name” : “?”}}, {“field” : {“price” : “?”}} ]}}
IsfindByName{“bool” : {“must” : {“field” : {“name” : “?”}}}}
NotfindByNameNot{“bool” : {“must_not” : {“field” : {“name” : “?”}}}}
BetweenfindByPriceBetween{“bool” : {“must” : {“range” : {“price” : {“from” : ?,“to” : ?,“include_lower” : true,“include_upper” : true}}}}}
LikefindByNameLike{“bool” : {“must” : {“field” : {“name” : {“query” : “?*”,“analyze_wildcard” : true}}}}}
InfindByNameIn(Collectionnames){“bool” : {“must” : {“bool” : {“should” : [ {“field” : {“name” : “?”}}, {“field” : {“name” : “?”}} ]}}}}
OrderByfindByAvailableTrueOrderByNameDesc{“sort” : [{ “name” : {“order” : “desc”} }],“bool” : {“must” : {“field” : {“available” : true}}}}

另外,由于与jap类似,所以是可以使用@Query的,这个可以自行去探索,本文只进行最简单的入门级整合。

测试

package com.th.elasticsearch;

import com.th.elasticsearch.mapper.UserMapper;
import com.th.elasticsearch.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.elasticsearch.core.ElasticsearchRestTemplate;

import javax.annotation.Resource;
import java.util.List;

@SpringBootTest
class ElasticSearchApplicationTests {
    @Resource
    private ElasticsearchRestTemplate template;

    @Autowired
    private UserMapper userMapper;

    //创建索引
    @Test
    public void createIndex() {
        //创建User对象的索引,事实上,系统初始化会自动创建索引
        boolean b = template.indexOps(User.class).create();
        System.out.println(b);
    }
    //删除索引
    @Test
    public void deleteIndex() {
        boolean b = template.indexOps(User.class).delete();
        System.out.println(b);
    }

    //新增文档
    @Test
    public void createMapping() {
        User user = new User();
        user.setId(1);
        user.setName("张三");
        user.setAge(18);
        user.setSex(false);
        User save = userMapper.save(user);
        System.out.println(save);
    }
    //查看全部文档
    @Test
    public void findAll() {
        Iterable<User> all = userMapper.findAll();
        System.out.println(all);
    }
    //按条件查询
    @Test
    public void findCondition() {
        //按照条件查询,需要自己去自定义查询方法
        //这里使用自定义的根据姓名和价格的查询方法
        List<User> list = userMapper.findAllByNameAndAge("张三", 18);
        System.out.println(list);
    }
}

至此整合Spring Boot就结束了,当然这只是最简单的入门级操作,一些更高级的操作需要在此基础上进行拓展。

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
首先,确保你已经安装了 Elasticsearch 并启动了服务。接下来,可以按照以下步骤整合 Spring BootElasticsearch。 1. 添加 Elasticsearch 依赖 在 pom.xml 文件中添加 Elasticsearch 的依赖: ```xml <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>elasticsearch-rest-high-level-client</artifactId> <version>7.12.1</version> </dependency> ``` 2. 配置 Elasticsearch 连接 在 application.properties 文件中添加 Elasticsearch 连接配置: ```properties spring.elasticsearch.rest.uris=http://localhost:9200 ``` 3. 定义 Elasticsearch 实体类 定义一个实体类,用于与 Elasticsearch 进行数据交互。例如,定义一个名为 `Book` 的实体类: ```java @Data @NoArgsConstructor @AllArgsConstructor @Builder @Document(indexName = "book") public class Book { @Id private String id; private String title; private String author; } ``` 注解说明: - `@Data`:生成 getter、setter 方法等。 - `@NoArgsConstructor` 和 `@AllArgsConstructor`:生成无参构造函数和全参构造函数。 - `@Builder`:生成一个建造者模式的构造器。 - `@Document(indexName = "book")`:表明该实体类对应 Elasticsearch 中的 `book` 索引。 4. 定义 Elasticsearch 数据访问层 定义一个数据访问层接口,用于对 Elasticsearch 进行数据操作。例如,定义一个名为 `BookRepository` 的接口: ```java public interface BookRepository extends ElasticsearchRepository<Book, String> { } ``` 注解说明: - `@ElasticsearchRepository`:继承自 Spring Data Elasticsearch,提供了丰富的数据访问方法。 5. 测试 Elasticsearch 数据访问 在 Spring Boot 应用中使用 `BookRepository` 进行数据访问。例如,定义一个名为 `BookService` 的服务类: ```java @Service @AllArgsConstructor public class BookService { private final BookRepository bookRepository; public void save(Book book) { bookRepository.save(book); } public List<Book> search(String keyword) { QueryBuilder queryBuilder = QueryBuilders.boolQuery() .should(QueryBuilders.matchQuery("title", keyword)) .should(QueryBuilders.matchQuery("author", keyword)); SearchQuery searchQuery = new NativeSearchQueryBuilder() .withQuery(queryBuilder) .build(); return bookRepository.search(searchQuery).get().map(SearchHit::getContent).collect(Collectors.toList()); } } ``` 注解说明: - `@Service`:声明该类是一个 Spring Bean。 - `@AllArgsConstructor`:生成一个全参构造函数。 - `bookRepository`:通过构造函数进行依赖注入。 - `save` 方法:保存一本书到 Elasticsearch 中。 - `search` 方法:根据关键词搜索书籍。 6. 测试 Elasticsearch 数据访问 最后,可以编写一个测试类来测试 Elasticsearch 数据访问。例如,定义一个名为 `BookServiceTest` 的测试类: ```java @SpringBootTest class BookServiceTest { @Autowired private BookService bookService; @BeforeEach void setUp() { bookService.save(Book.builder().id("1").title("Java").author("Tom").build()); bookService.save(Book.builder().id("2").title("C++").author("Jack").build()); bookService.save(Book.builder().id("3").title("Python").author("Chris").build()); } @Test void search() { List<Book> books = bookService.search("Java"); assertThat(books).hasSize(1); assertThat(books.get(0).getTitle()).isEqualTo("Java"); } } ``` 注解说明: - `@SpringBootTest`:声明该类是一个 Spring Boot 测试类。 - `bookService`:通过自动注入进行依赖注入。 - `setUp` 方法:在每个测试方法执行前,先向 Elasticsearch 中添加三本书籍。 - `search` 方法:根据关键词 `Java` 搜索书籍,并断言返回的结果。 以上就是整合 Spring BootElasticsearch 的步骤。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值