开发者社区> 老先生二号> 正文

Spring data JPA中使用Specifications动态构建查询

简介:
+关注继续查看

有时我们在查询某个实体的时候,给定的条件是不固定的,这是我们就需要动态 构建相应的查询语句,在JPA2.0中我们可以通过Criteria接口查询,JPA criteria查询.相比JPQL,其优势是类型安全,更加的面向对象.而在Spring data JPA中相应的接口是JpaSpecificationExecutor,这个接口基本是围绕着Specification接口来定义的。 Specification接口中只定义了如下一个方法:

我们只需要重写这个方法即可,相关知识请自行查阅JPA Criteria查询 

过滤条件

1:过滤条件会被应用到SQL语句的FROM子句中。在criteria 查询中,查询条件通过Predicate或Expression实例应用到CriteriaQuery对象上。

2:这些条件使用 CriteriaQuery .where 方法应用到CriteriaQuery 对象上

3:CriteriaBuilder也作为Predicate实例的工厂,通过调用CriteriaBuilder 的条件方法( equal,notEqual, gt, ge,lt, le,between,like等)创建Predicate对象。

4:复合的Predicate 语句可以使用CriteriaBuilder的and, or andnot 方法构建。

相关代码如下,在这个例子中我们定义了2个类Articel和User类

Article:

User:

其中user和article是一对多的关系,是单向的

封装的查询实体SearchArticle

下面是查询方法

其中的 ArticleRepository接口如下,spring data jpa不需要你自己实现dao的接口

通过以上的步骤,我们就能构建相应的查询sql了,使用这个接口要对JPA2.0中Criteria查询有一定的了解

分类: java

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/p/4661839.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
「Spring和Kafka」Kafka深挖第3部分:Kafka和Spring Cloud data Flow
「Spring和Kafka」Kafka深挖第3部分:Kafka和Spring Cloud data Flow
10 0
「首席架构师看事件流架构」Kafka深挖第3部分:Kafka和Spring Cloud data Flow
「首席架构师看事件流架构」Kafka深挖第3部分:Kafka和Spring Cloud data Flow
10 0
BXA
Spring Data JPA简化数据访问
Spring Data JPA是基于JPA规范的一个Spring Data模块,为开发者提供了一组通用的、具有一致性的API,使得对于多种数据存储的访问变得容易。它不仅简化了JPA应用开发,还提供了许多特性,如自定义方法、查询构造、分页和排序等。
22 0
BXA
Spring Data Redis实现高性能缓存
随着互联网的普及Web应用的开发变得越来越普遍。然而,随着应用规模和用户数量的增加也会面临越来越多的性能问题。Web应用性能的瓶颈通常出现在以下几个方面: - 数据库查询和写入延迟 - 网络传输延迟 - 高并发请求压力
17 0
Spring Data默认值的错误
Spring Data有很多配置的默认值,但不一定都适合你。如一个依赖Cassandra 的项目,有时写入数据后,并不能立马读到。这种错误并没有什么报错,一切都是正常的,就是读不到数据。
18 0
用好 DDD 必须先过 Spring Data 这关
用好 DDD 必须先过 Spring Data 这关
32 0
Spring Data Elasticsearch 5.0升级指南
Spring Data Elasticsearch 5.0升级指南
388 0
Spring Data 简介
Spring Data的使命是为数据访问提供一个熟悉且一致的,基于Spring的编程模型
53 0
Spring Data JPA中常用的注解详解
我们先看看类前面的两个注解
63 0
【Elasticsearch】整合Spring Data Elasticsearch(二)
【Elasticsearch】整合Spring Data Elasticsearch
116 0
+关注
老先生二号
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库
立即下载
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
相关实验场景
更多