深入浅出 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 带分页已经支持。如图:
2.3 ElasticsearchTemplate
ES 数据操作的中心支持类。和 JdbcTemplate 一样,几乎所有操作都可以使用 ElasticsearchTemplate 来完成。
ElasticsearchTemplate 实现了 ElasticsearchOperations 和 ApplicationContextAware 接口。ElasticsearchOperations 接口提供了 ES 相关的操作,并将 ElasticsearchTemplate 加入到 Spring 上下文。如图:
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 核心接口及版本的情况。
资料:
项目地址
https://github.com/spring-proj ... earch
官方文档
http://docs.spring.io/spring-data/elasticsearch/docs/current/reference/html/
【本文为51CTO专栏作者“李强强”的原创稿件,转载请通过51CTO联系作者获取授权】
相关文章
- 润和Hi3516开发板OpenHarmony小型系统、标准系统烧录
- 【FFH】小熊派驱动调用流程(以调用LED灯驱动为例)
- 服务器性能优化之网络性能优化
- Preset-Env 按需 Polyfill 是怎么实现的?
- Windows不安装虚拟机如何使用Linux系统作为开发工具?
- 一款运行于Windows上的Linux命令神器-Cmder(已经爱不释手)
- Spring认证_什么是Spring GraphQL?
- 跟我学Linux:apt命令快速参考指南
- oeasy教您玩转vim – 11 – # 向前向后
- 谷歌推出 Chrome OS Flex 系统,可将旧电脑变成 Chromebook
- Wine 7.2 发布,Linux下安装使用最新版QQ与微信
- xtrabackup 增量,全备份,恢复备份
- windows 远程桌面连接提示:出现了内部错误,windows远程桌面登录linux闪退
- 基于java springboot垃圾分类小程序源码(毕设)
- oeasy教您玩转vim – 10 – # 插入新行
- golang 系列: mutex 讲解
- 云服务器系统哪个好用吗
- 哈雷推出电动摩托车,超400万元收购品牌域名LiveWire.com
- 直观对比了解Windows 10和Windows 11,才知道最好用的系统是这个
- 至暗时刻,风“云”突变(四):2015到2019,从5到70,从0到100万,技术推动业务的云实践,我创业的这4年