深入浅出 spring-data-elasticsearch 系列 - 概述及入门

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

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

本文目录

一、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 系列 - 概述及入门

一、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 依赖

  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 通用的存储接口的一种默认实现。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 操作。

  1. publicinterfaceBookRepositoryextendsRepository<Book,String>{List<Book>findByNameAndPrice(Stringname,Integerprice);List<Book>findByNameOrPrice(Stringname,Integerprice);Page<Book>findByName(Stringname,Pageablepage);Page<Book>findByNameNot(Stringname,Pageablepage);Page<Book>findByPriceBetween(intprice,Pageablepage);Page<Book>findByNameLike(Stringname,Pageablepage);@Query("{\"bool\":{\"must\":{\"term\":{\"message\":\"?0\"}}}}")Page<Book>findByMessage(Stringmessage,Pageablepageable);
  2. }

三、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 核心接口及版本的情况。

资料:

项目地址

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

官方文档

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

【本文为清一色专栏作者“李强强”的原创稿件,转载请通过清一色联系作者获取授权】

戳这里,看该作者更多好文

©本文为清一色官方代发,观点仅代表作者本人,与清一色无关。清一色对文中陈述、观点判断保持中立,不对所包含内容的准确性、可靠性或完整性提供任何明示或暗示的保证。本文不作为投资理财建议,请读者仅作参考,并请自行承担全部责任。文中部分文字/图片/视频/音频等来源于网络,如侵犯到著作权人的权利,请与我们联系(微信/QQ:1074760229)。转载请注明出处:清一色财经

(0)
打赏 微信扫码打赏 微信扫码打赏 支付宝扫码打赏 支付宝扫码打赏
清一色的头像清一色管理团队
上一篇 2023年5月6日 03:57
下一篇 2023年5月6日 03:58

相关推荐

发表评论

登录后才能评论

联系我们

在线咨询:1643011589-QQbutton

手机:13798586780

QQ/微信:1074760229

QQ群:551893940

工作时间:工作日9:00-18:00,节假日休息

关注微信