springboot检索之整合elasticsearch并使用spring-data操作

Posted 西西嘛呦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springboot检索之整合elasticsearch并使用spring-data操作相关的知识,希望对你有一定的参考价值。

各种过时,版本不兼容,只能暂时将代码放在这先做参考了。

pom.xml

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

Book.java

package com.gong.spingbootes.bean;

import org.springframework.data.elasticsearch.annotations.Document;

//这里必须指明索引名字和类型 @Document(indexName
= "gong",type = "book") public class Book { private Integer id; private String bookName; private String author; public Book(){} public Book(Integer id, String bookName, String author) { this.id = id; this.bookName = bookName; this.author = author; } @Override public String toString() { return "Book{" + "id=" + id + ", bookName=‘" + bookName + ‘‘‘ + ", author=‘" + author + ‘‘‘ + ‘}‘; } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getBookName() { return bookName; } public void setBookName(String bookName) { this.bookName = bookName; } public String getAuthor() { return author; } public void setAuthor(String author) { this.author = author; } }

BookRepository.java

package com.gong.spingbootes.repository;

import com.gong.spingbootes.bean.Book;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

import java.util.List;
//第一个泛型是对象类型,第二个泛型是book的主键
public interface BookRepository extends ElasticsearchRepository<Book,Integer>{
   //这里的名字不是随意取的,而是根据查询需求来取的,具体可参考相关文档
public List<Book> findByBookNameLike(String bookName); }

application.properties

spring.data.elasticsearch.cluster-name=elasticsearch
spring.data.elasticsearch.cluster-nodes=192.168.124.22
#这两玩意过时了

SpringbootEsApplicationTests.java

package com.gong.spingbootes;

import com.gong.spingbootes.bean.Article;
import com.gong.spingbootes.bean.Book;
import com.gong.spingbootes.repository.BookRepository;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;


@RunWith(SpringRunner.class)
@SpringBootTest
public class SpingbootEsApplicationTests {

    @Autowired
    BookRepository bookRepository;

    @Test
    public void contextLoads() {
    }

  //添加索引 @Test
public void index() { bookRepository.index(new Book(1,"java","德玛")); }
  //进行查询 @Test
public void search() { bookRepository.findByBookNameLike("ja"); } }

 

以上是关于springboot检索之整合elasticsearch并使用spring-data操作的主要内容,如果未能解决你的问题,请参考以下文章

springboot+elasticsearch + rabbitMQ实现全文检索(springboot+ES整合)

SpringBoot-spring-data-elasticsearch7.12.0

springboot整合logback集成elk实现日志的汇总分析统计和检索功能

SpringBoot整合Elasticsearch-Rest-Client测试保存复杂检索

十一.全文检索ElasticSearch经典入门-SpringBoot整合ElasticSearch7

十一.全文检索ElasticSearch经典入门-SpringBoot整合ElasticSearch7