自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

深入淺出 spring-data-elasticsearch 系列 - 概述及入門

大數(shù)據(jù)
Spring Data 基于 Spring 為數(shù)據(jù)訪問(wèn)提供一種相似且一致性的編程模型,并保存底層數(shù)據(jù)存儲(chǔ)的。

本文目錄

一、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 版本

四、小結(jié)

一、spring-data-elasticsearch 是什么?

1.1 Spring Data

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

Spring Data 基于 Spring 為數(shù)據(jù)訪問(wèn)提供一種相似且一致性的編程模型,并保存底層數(shù)據(jù)存儲(chǔ)的。

1.2 Spring Data Elasticsearch

spring-data-elasticsearch 是 Spring Data 的 Community modules 之一,是 Spring Data 對(duì) Elasticsearch 引擎的實(shí)現(xiàn)。

Elasticsearch 默認(rèn)提供輕量級(jí)的 HTTP Restful 接口形式的訪問(wèn)。相對(duì)來(lái)說(shuō),使用 HTTP Client 調(diào)用也很簡(jiǎn)單。但 spring-data-elasticsearch 可以更快的支持構(gòu)建在 Spring 應(yīng)用上,比如在 application.properties 配置 ES 節(jié)點(diǎn)信息和 spring-boot-starter-data-elasticsearch 依賴,直接在 Spring Boot 應(yīng)用上使用。

二、spring-data-elasticsearch 快速入門

2.1 pom.xml 依賴

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

2.2 ElasticsearchRepository

ES 通用的存儲(chǔ)接口的一種默認(rèn)實(shí)現(xiàn)。Spring 根據(jù)接口定義的方法名,具體執(zhí)行對(duì)應(yīng)的數(shù)據(jù)存儲(chǔ)實(shí)現(xiàn)。

ElasticsearchRepository 繼承 ElasticsearchCrudRepository ,ElasticsearchCrudRepository 繼承 PagingAndSortingRepository。所以一般 CRUD 帶分頁(yè)已經(jīng)支持。如圖:

2.3 ElasticsearchTemplate

ES 數(shù)據(jù)操作的中心支持類。和 JdbcTemplate 一樣,幾乎所有操作都可以使用 ElasticsearchTemplate 來(lái)完成。

ElasticsearchTemplate 實(shí)現(xiàn)了 ElasticsearchOperations 和 ApplicationContextAware 接口。ElasticsearchOperations 接口提供了 ES 相關(guān)的操作,并將 ElasticsearchTemplate 加入到 Spring 上下文。如圖:

2.4 使用案例

拿官方案例來(lái)吧,詳細(xì)介紹了 Book ES 對(duì)象的接口實(shí)現(xiàn)。

可以看出,book 擁有 name 和 price 兩個(gè)屬性。下面支持 name 和 price 列表 ES 查詢,分頁(yè)查詢,范圍查詢等。還有可以利用注解實(shí)現(xiàn) DSL 操作。

  1. public interface BookRepository extends Repository<Book, String> {        List<Book> findByNameAndPrice(String nameInteger price);        List<Book> findByNameOrPrice(String nameInteger 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); 
  2.    } 

三、spring-data-elasticsearch 和 elasticsearch 版本

SpringBoot 1.5+ 目前僅支持 ElasticSearch 2.3.2,所以如果想要使用***的 ES??梢酝ㄟ^(guò)默認(rèn)的輕量級(jí)的 HTTP 去調(diào)用實(shí)現(xiàn)。其版本對(duì)應(yīng)如下:

  • 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

四、小結(jié)

本小結(jié)介紹了 spring-data-elasticsearch 是概述以及它的入門,還有 spring-data-elasticsearch 核心接口及版本的情況。

資料:

項(xiàng)目地址

https://github.com/spring-proj ... earch

官方文檔

http://docs.spring.io/spring-data/elasticsearch/docs/current/reference/html/

【本文為51CTO專欄作者“李強(qiáng)強(qiáng)”的原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)通過(guò)51CTO聯(lián)系作者獲取授權(quán)】

戳這里,看該作者更多好文

責(zé)任編輯:武曉燕 來(lái)源: 51CTO專欄
相關(guān)推薦

2017-06-06 15:24:13

springElasticSear架構(gòu)

2017-06-20 15:20:54

spring-data案例詳解

2025-03-27 09:38:35

2021-03-16 08:54:35

AQSAbstractQueJava

2011-07-04 10:39:57

Web

2022-01-12 08:54:52

Spring編程架構(gòu)設(shè)計(jì)

2020-05-27 20:25:47

SpringSpringBoot數(shù)據(jù)

2017-07-02 18:04:53

塊加密算法AES算法

2019-01-07 15:29:07

HadoopYarn架構(gòu)調(diào)度器

2021-07-20 15:20:02

FlatBuffers阿里云Java

2012-05-21 10:06:26

FrameworkCocoa

2022-09-26 09:01:15

語(yǔ)言數(shù)據(jù)JavaScript

2017-08-24 15:09:13

GAN神經(jīng)網(wǎng)絡(luò)無(wú)監(jiān)督學(xué)習(xí)

2022-09-29 09:19:04

線程池并發(fā)線程

2011-01-27 10:11:46

J2EEjavaspring

2010-07-26 12:57:12

OPhone游戲開(kāi)發(fā)

2016-10-14 13:53:05

JavascriptDOMWeb

2016-10-14 14:32:58

JavascriptDOMWeb

2009-11-17 17:31:58

Oracle COMM

2021-07-19 11:54:15

MySQL優(yōu)先隊(duì)列
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)