本文目錄
1、spring-data-elasticsearch 是什麼?
1.1 Spring Data
1.2 Spring Data Elasticsearch
2、spring-data-elasticsearch 快速入門
2.1 pom.xml 依賴
2.2 ElasticsearchRepository
2.3 ElasticsearchTemplate
2.4 使用案例
3、spring-data-elasticsearch 和 elasticsearch 版本
4、小結java
這裏咱們只是把人生大體分紅「學習階段」以及以後的「工做階段」。
-《將來簡史》
1.1 Spring Data
要了解 spring-data-elasticsearch 是什麼,首先了解什麼是 Spring Data。
Spring Data 基於 Spring 爲數據訪問提供一種類似且一致性的編程模型,並保存底層數據存儲的。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 應用上使用。編程
2.1 pom.xml 依賴app
<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 帶分頁已經支持。如圖:elasticsearch
2.3 ElasticsearchTemplate
ES 數據操做的中心支持類。和 JdbcTemplate 同樣,幾乎全部操做均可以使用 ElasticsearchTemplate 來完成。
ElasticsearchTemplate 實現了 ElasticsearchOperations 和 ApplicationContextAware 接口。ElasticsearchOperations 接口提供了 ES 相關的操做,並將 ElasticsearchTemplate 加入到 Spring 上下文。如圖:spring-boot
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); }
SpringBoot 1.5+ 目前僅支持 ElasticSearch 2.3.2,因此若是想要使用最新的 ES。能夠經過默認的輕量級的 HTTP 去調用實現。其版本對應以下:spa
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.1code
本小結介紹了 spring-data-elasticsearch 是概述以及它的入門,還有 spring-data-elasticsearch 核心接口及版本的狀況。xml