博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring-data-elasticsearch 概述及入门(二)
阅读量:6497 次
发布时间:2019-06-24

本文共 2679 字,大约阅读时间需要 8 分钟。

hot3.png

本文目录

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

org.springframework.data
spring-data-elasticsearch
x.y.z.RELEASE

2.2 ElasticsearchRepository

ES 通用的存储接口的一种默认实现。Spring 根据接口定义的方法名,具体执行对应的数据存储实现。
ElasticsearchRepository 继承 ElasticsearchCrudRepository ElasticsearchCrudRepository 继承 PagingAndSortingRepository。所以一般 CRUD 带分页已经支持。如图:

195642_yFmc_3664884.png

2.3 ElasticsearchTemplate

ES 数据操作的中心支持类。和 JdbcTemplate 一样,几乎所有操作都可以使用 ElasticsearchTemplate 来完成。
ElasticsearchTemplate 实现了 ElasticsearchOperations 和 ApplicationContextAware 接口。ElasticsearchOperations 接口提供了 ES 相关的操作,并将 ElasticsearchTemplate 加入到 Spring 上下文。如图:

195655_blD8_3664884.png

2.4 使用案例

拿官方案例来吧,详细介绍了 Book ES 对象的接口实现。
可以看出,book 拥有 name 和 price 两个属性。下面支持 name 和 price 列表 ES 查询,分页查询,范围查询等。还有可以利用注解实现 DSL 操作。

 

public interface BookRepository extends Repository
{ List
findByNameAndPrice(String name, Integer price); List
findByNameOrPrice(String name, Integer price); Page
findByName(String name,Pageable page); Page
findByNameNot(String name,Pageable page); Page
findByPriceBetween(int price,Pageable page); Page
findByNameLike(String name,Pageable page); @Query("{\"bool\" : {\"must\" : {\"term\" : {\"message\" : \"?0\"}}}}") Page
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://my.oschina.net/u/3664884/blog/1811757

你可能感兴趣的文章
1.JSONObject与JSONArray的使用
查看>>
34.TokenInterceptor防止表单重复提交
查看>>
cogs 362. [CEOI2004]锯木厂选址
查看>>
Sql Server 因为触发器问题导致数据库更新报错“在触发器执行过程中引发了错误,批处理已中止”的问题处理...
查看>>
npm-debug.log文件出现原因
查看>>
You may remembe MBT Changa
查看>>
洛谷P3723 [AH2017/HNOI2017]礼物(FFT)
查看>>
洛谷P4705 玩游戏(生成函数+多项式运算)
查看>>
Vue API(directives) 自定义指令
查看>>
9.8.6恢复系统数据库
查看>>
权限组件(10):三级菜单的展示和增删改查
查看>>
搭建Jupyter学习环境
查看>>
中国大学MOOC-C程序设计(浙大翁恺)—— 时间换算
查看>>
最好的品质
查看>>
C#综合揭秘——Entity Framework 并发处理详解
查看>>
mui 微信支付 与springMVC服务器交互
查看>>
传参防SQL注入函数
查看>>
Java Web整合开发读书笔记
查看>>
linux 安装安装rz/sz 和 ssh
查看>>
课堂练习(续)
查看>>