Springboot整合Elasticsearch-CRUD+分页查询

ES-docker安装参考这篇: Centos7使用Docker部署Elasticsearch服务+IK分词器及Head插件安装
ES-windows安装参考这篇: windows10安装ElasticSearch与Head-master+IK分词器安装与自定义词库

1. 环境配置

pom.xml

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

application.yml

server:
  port: 9001 #端口号
spring:
  application:
    name: sunmone-search #服务名称
  data:
    elasticsearch:
      cluster-nodes: 192.168.1.158:9300 # ES服务地址

实体类

import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;
import org.springframework.data.elasticsearch.annotations.Field;

/*
 * @Document(indexName = "索引名称",type = "表名称")
 * 如果索引不存在,那么将会自动创建索引,type同理
 * */
@Document(indexName = "tensquare", type = "article")
public class Article implements Serializable {

    @Id // @Id 让ES知道这个字段是_id
    private String id;

    // 字段开启分词,分词规则: 最细粒度切分,搜索规则:最细粒度搜索
    @Field(index = true, analyzer = "ik_max_word", searchAnalyzer = "ik_max_word")
    private String title;

    // 字段开启分词,分词规则: 最细粒度切分,搜索规则:最细粒度搜索
    @Field(index = true, analyzer = "ik_max_word", searchAnalyzer = "ik_max_word")
    private String content;
    private String state;
    
	... GET AND SET ...
}

启动类

@SpringBootApplication
public class SearchApplication {
    public static void main(String[] args) {
        SpringApplication.run(SearchApplication.class);
    }
}

2. 代码编写

2.1 Dao层

// SpringBoot使用ES,继承 ElasticsearchRepository <实体类,主键ID类型>
public interface ArticleDao extends ElasticsearchRepository<Article, String> {

    // 按关键词分页查询
    public Page<Article> findByTitleLikeOrContentLike(String title, String content, Pageable pageable);
}

2.2 Service层


@Service
public class ArticleService {
    @Autowired
    private ArticleDao articleDao;

    // 按关键词分页查询
    public Page<Article> search(String keywords, int page, int size) {
        PageRequest pageRequest = PageRequest.of(page - 1, size);
        return articleDao.findByTitleLikeOrContentLike(keywords, keywords, pageRequest);
    }
    // 添加数据 以下语法跟mysql一致
    public void save(Article article) {
    // 这里记得设置ID,我用的工具类雪花ID
        article.setId("1");
        articleDao.save(article);
    }
    // 修改
    public void update(Article article) {
        articleDao.save(article);
    }
    // 删除
    public void deleteById(String id) {
        articleDao.deleteById(id);
    }
    // 按ID查询
    public Article findById(String id) {
        return articleDao.findById(id).get();
    }
}

2.2 Controller层


@RestController
@CrossOrigin
@RequestMapping("/article")
public class ArticleController {
    @Autowired
    private ArticleService articleService;

    // 添加数据
    @RequestMapping(method = RequestMethod.POST)
    public Result save(@RequestBody Article article) {
        articleService.save(article);
        return new Result(true, StatusCode.OK, "添加成功");
    }

    // 关键词分页查询
    @RequestMapping(value = "search/{keywords}/{page}/{size}", method = RequestMethod.GET)
    public Result search(@PathVariable String keywords, @PathVariable int page, @PathVariable int size) {
        Page<Article> search = articleService.search(keywords, page, size);
        return new Result(true, StatusCode.OK, "查询成功",
                new PageResult(search.getTotalElements(), search.getContent()));
    }
}

3. 测试结果

我手动添加了几条数据

在这里插入图片描述
在Head插件中查看

在这里插入图片描述
搜索成功

在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为您提供一些关于Spring Boot整合Easy Elasticsearch的指导。 1. 添加依赖 首先,在`pom.xml`文件中添加Easy ElasticsearchElasticsearch的依赖: ```xml <dependency> <groupId>com.jun</groupId> <artifactId>easy-elasticsearch-spring-boot-starter</artifactId> <version>1.0.0</version> </dependency> <dependency> <groupId>org.elasticsearch.client</groupId> <artifactId>elasticsearch-rest-high-level-client</artifactId> <version>7.12.0</version> </dependency> ``` 2. 配置Elasticsearch 在`application.yml`中添加Elasticsearch的配置信息: ```yaml spring: elasticsearch: rest: uris: http://localhost:9200 ``` 3. 创建Elasticsearch的Repository 创建一个继承自`ElasticsearchRepository`的接口,用于定义Elasticsearch的操作方法: ```java public interface BookRepository extends ElasticsearchRepository<Book, Long> { List<Book> findBooksByAuthor(String author); } ``` 其中,`Book`是我们要操作的实体类,`Long`是这个实体类的ID类型。 4. 测试Elasticsearch 可以编写一个测试方法来测试Elasticsearch是否成功整合: ```java @SpringBootTest class BookRepositoryTest { @Autowired private BookRepository bookRepository; @Test public void testSave() { Book book = new Book(); book.setId(1L); book.setTitle("Java编程思想"); book.setAuthor("Bruce Eckel"); bookRepository.save(book); } @Test public void testFind() { List<Book> books = bookRepository.findBooksByAuthor("Bruce Eckel"); System.out.println(books); } } ``` 执行测试方法后,如果能够正确输出结果,则说明Easy Elasticsearch已经成功整合到了Spring Boot中。 希望这些步骤能够对您有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

叫我三胖哥哥

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

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

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

打赏作者

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

抵扣说明:

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

余额充值