深入浅出 spring-data-elasticsearch 系列 – 概述及入门(二)

栏目: Java · 发布时间: 7年前

内容简介:深入浅出 spring-data-elasticsearch 系列 – 概述及入门(二)

本文目录

一、spring-data-elasticsearch 是什么?

1.1 Spring Data

1.2 Spring Data Elasticsearch

二、spring-data-elasticsearch 快速入门

2.1 pom.xml 依赖

2.2 ElasticsearchRepository

2.3 ElasticsearchTemplate

2.4 使用案例

三、spring-data-elasticsearch 和 elasticsearch 版本

四、小结

这里我们只是把人生大致分成“学习阶段”以及之后的“工作阶段”。

-《未来简史》

一、spring-data-elasticsearch 是什么?

1.1 Spring Data

要了解 spring-data-elasticsearch 是什么,首先了解什么是 Spring Data。

Spring Data 基于 Spring 为数据访问提供一种相似且一致性的编程模型,并保存底层数据存储的。

1.2 Spring Data Elasticsearch

spring-data-elasticsearch 是 Spring Data 的 Community modules 之一,是 Spring Data 对 Elasticsearch 引擎的实现。

Elasticsearch 默认提供轻量级的 HTTP Restful 接口形式的访问。相对来说,使用 HTTP Client 调用也很简单。但 spring-data-elasticsearch 可以更快的支持构建在 Spring 应用上,比如在 application.properties 配置 ES 节点信息和 spring-boot-starter-data-elasticsearch 依赖,直接在 Spring Boot 应用上使用。

二、spring-data-elasticsearch 快速入门

2.1 pom.xml 依赖

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-elasticsearch</artifactId>
    <version>x.y.z.RELEASE</version>
</dependency>

2.2 ElasticsearchRepository

ES 通用的存储接口的一种默认实现。Spring 根据接口定义的方法名,具体执行对应的数据存储实现。

ElasticsearchRepository 继承 ElasticsearchCrudRepository ,ElasticsearchCrudRepository 继承 PagingAndSortingRepository。所以一般 CRUD 带分页已经支持。如图:

深入浅出 spring-data-elasticsearch 系列 – 概述及入门(二)

2.3 ElasticsearchTemplate

ES 数据操作的中心支持类。和 JdbcTemplate 一样,几乎所有操作都可以使用 ElasticsearchTemplate 来完成。

ElasticsearchTemplate 实现了 ElasticsearchOperations 和 ApplicationContextAware 接口。ElasticsearchOperations 接口提供了 ES 相关的操作,并将 ElasticsearchTemplate 加入到 Spring 上下文。如图:

深入浅出 spring-data-elasticsearch 系列 – 概述及入门(二)

2.4 使用案例

拿官方案例来吧,详细介绍了 Book ES 对象的接口实现。

可以看出,book 拥有 name 和 price 两个属性。下面支持  name 和 price 列表 ES 查询,分页查询,范围查询等。还有可以利用注解实现 DSL 操作。

public interface BookRepository extends Repository<Book, String> {
        List<Book> findByNameAndPrice(String name, Integer price);
        List<Book> findByNameOrPrice(String name, Integer price);
        Page<Book> findByName(String name,Pageable page);
        Page<Book> findByNameNot(String name,Pageable page);
        Page<Book> findByPriceBetween(int price,Pageable page);
        Page<Book> findByNameLike(String name,Pageable page);
        @Query("{\"bool\" : {\"must\" : {\"term\" : {\"message\" : \"?0\"}}}}")
        Page<Book> findByMessage(String message, Pageable pageable);
    }

三、spring-data-elasticsearch 和 elasticsearch 版本

SpringBoot 1.5+ 目前仅支持 ElasticSearch 2.3.2,所以如果想要使用最新的 ES。可以通过默认的轻量级的 HTTP 去调用实现。其版本对应如下:

spring data elasticsearch    elasticsearch

3.0.0.BUILD-SNAPSHOT    5.4.0

2.0.4.RELEASE                    2.4.0

2.0.0.RELEASE                    2.2.0

1.4.0.M1                               1.7.3

1.3.0.RELEASE                    1.5.2

1.2.0.RELEASE                    1.4.4

1.1.0.RELEASE                    1.3.2

1.0.0.RELEASE                    1.1.1

四、小结

本小结介绍了 spring-data-elasticsearch 是概述以及它的入门,还有 spring-data-elasticsearch 核心接口及版本的情况。

本文作者: 泥瓦匠

原文链接:  http://www.bysocket.com

版权归作者所有,转载请注明出处


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

轻公司

轻公司

李黎、杜晨 / 中信出版社 / 2009-7 / 39.00元

《轻公司》解读了在互联网和IT技术越来越充裕的环境里,传统的商业法则是如何被打破,而新的商业法则如何建立起来的过程。大量生动翔实的采访,为我们构筑了互联网和IT技术影响下的未来商业趋势。李黎和杜晨在《IT经理世界》上发表了一篇封面报道《轻公司》后,迅速在传统行业及互联网行业产生极大反响,无论是老牌的传统企业、创业公司、风险投资商,都视这篇文章为新商业宝典,甚至有业界人士评价,这篇文章拯救了中国的电......一起来看看 《轻公司》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

在线进制转换器
在线进制转换器

各进制数互转换器

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具