Spring Data ElasticSearch的简介和入门使用

本文介绍了Spring Data ElasticSearch的基本概念,它是一个基于Spring Data API简化ElasticSearch操作的框架。文章详细阐述了如何入门使用,包括导入依赖、配置文件、创建实体类、编写Dao和服务,以及使用注解配置索引和映射。
摘要由CSDN通过智能技术生成

1.Spring Data ElasticSearch的简介

1.1什么是Spring Data

    Spring Data是一个用于简化数据库访问,并支持云服务的开源框架。其主要目标是使得对数据的访问变得方便快捷,并支持map-reduce框架和云计算数据服务。 Spring Data可以极大的简化JPA的写法,可以在几乎不用写实现的情况下,实现对数据的访问和操作。除了CRUD外,还包括如分页、排序等一些常用的功能。

Spring Data的官网:http://projects.spring.io/spring-data/

1.2什么是Spring Data ElasticSearch

    Spring Data ElasticSearch 基于 spring data API 简化 elasticSearch操作,将原始操作elasticSearch的客户端API进行封装。Spring Data为Elasticsearch项目提供集成搜索引擎。Spring Data Elasticsearch POJO的关键功能区域为中心的模型与Elastichsearch交互文档和轻松地编写一个存储库数据访问层。
官方网站:http://projects.spring.io/spring-data-elasticsearch/

2.Spring Data ElasticSearch的入门使用

(1)导入Spring Data ElasticSearch依赖包

<?xmlversion="1.0" encoding="UTF‐8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema‐instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven‐4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.itheima</groupId>
    <artifactId>itheima_elasticsearch_demo3</artifactId>
    <version>1.0‐SNAPSHOT</version>
    
    <dependencies>
        <dependency>
            <groupId>org.elasticsearch</groupId>
            <artifactId>elasticsearch</artifactId>
            <version>5.6.8</version>
        </dependency>
        <dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>transport</artifactId>
            <version>5.6.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j‐to‐slf4j</artifa
Spring Data ElasticsearchSpring Data家族中的一个模块,提供了ElasticsearchSpring集成支持。本教程将介绍如何使用Spring Data Elasticsearch4.1.0。 1. 添加依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-elasticsearch</artifactId> <version>4.1.0</version> </dependency> ``` 2. 配置Elasticsearch连接信息 在application.properties或application.yml中添加以下配置: ```yaml spring.data.elasticsearch.cluster-name=my-application spring.data.elasticsearch.cluster-nodes=localhost:9300 ``` 其中,cluster-name为Elasticsearch集群的名称,cluster-nodes为Elasticsearch集群中连接节点的地址和端口号。 3. 定义实体类 定义一个实体类,并使用@Document注解标识为Elasticsearch文档对象。如: ```java @Document(indexName = "book", createIndex = false) public class Book { @Id private String id; private String name; private String author; private String description; // getter and setter } ``` 其中,@Id注解标识为Elasticsearch文档对象的唯一标识字段。 4. 定义Elasticsearch操作接口 定义一个接口,并继承ElasticsearchRepository接口。如: ```java public interface BookRepository extends ElasticsearchRepository<Book, String> { } ``` 其中,Book为实体类,String为实体类的@Id注解标识的类型。 5. 使用Elasticsearch操作接口 在需要使用Elasticsearch的地方注入BookRepository,并使用其提供的方法进行操作。 ```java @Autowired private BookRepository bookRepository; @Test public void testSave() { Book book = new Book(); book.setId("1"); book.setName("Java编程思想"); book.setAuthor("Bruce Eckel"); book.setDescription("Java编程入门必读经典之作"); bookRepository.save(book); } @Test public void testFindById() { Optional<Book> optionalBook = bookRepository.findById("1"); assertNotNull(optionalBook); assertTrue(optionalBook.isPresent()); Book book = optionalBook.get(); assertEquals("Java编程思想", book.getName()); } @Test public void testFindByAuthor() { List<Book> bookList = bookRepository.findByAuthor("Bruce Eckel"); assertNotNull(bookList); assertEquals(1, bookList.size()); Book book = bookList.get(0); assertEquals("Java编程思想", book.getName()); } ``` 以上代码演示了如何保存文档,根据文档的唯一标识查询文档,以及根据其他字段查询文档。 以上就是使用Spring Data Elasticsearch4.1.0的基本教程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值