Spring Data JPA 从入门到精通~JpaSpecificationExecutor示例

新建两个实体

@Entity(name = "UserInfoEntity")
@Table(name = "user_info", schema = "test")
public class UserInfoEntity  implements Serializable {@Id@Column(name = "id", nullable = false)private Integer id;@Column(name = "first_name", nullable = true, length = 100)private String firstName;@Column(name = "last_name", nullable = true, length = 100)private String lastName;@Column(name = "telephone", nullable = true, length = 100)private String telephone;@Column(name = "create_time", nullable = true)private Date createTime;@Column(name = "version", nullable = true)private String version;@OneToOne(optional = false,fetch = FetchType.EAGER)@JoinColumn(referencedColumnName = "id",name = "address_id",nullable = false)@Fetch(FetchMode.JOIN)private UserReceivingAddressEntity addressEntity;
......
}@Entity
@Table(name = "user_receiving_address", schema = "test")
public class UserReceivingAddressEntity  implements Serializable {@Id@Column(name = "id", nullable = false)private Integer id;@Column(name = "user_id", nullable = false)private Integer userId;@Column(name = "address_city", nullable = true, length = 500)private String addressCity;
......
}

UserRepository 需要继承 JpaSpecificationExecutor

public interface UserRepository extends JpaSpecificationExecutor<UserInfoEntity> { }

调用者 UserInfoManager 的写法

  • 我们演示一下直接用 lambda 使用 Root<T> 和 CriteriaBuilder 做一个简单的不同条件的查询和链表查询。
@Component
public class UserInfoManager {@Autowiredprivate UserRepository userRepository;public Page<UserInfoEntity> findByCondition(UserInfoRequest userParam,Pageable pageable){return userRepository.findAll((root, query, cb) -> {List<Predicate> predicates = new ArrayList<Predicate>();if (StringUtils.isNoneBlank(userParam.getFirstName())){//liked的查询条件predicates.add(cb.like(root.get("firstName"),"%"+userParam.getFirstName()+"%"));}if (StringUtils.isNoneBlank(userParam.getTelephone())){//equal查询条件predicates.add(cb.equal(root.get("telephone"),userParam.getTelephone()));}if (StringUtils.isNoneBlank(userParam.getVersion())){//greaterThan大于等于查询条件predicates.add(cb.greaterThan(root.get("version"),userParam.getVersion()));}if (userParam.getBeginCreateTime()!=null&&userParam.getEndCreateTime()!=null){//根据时间区间去查询   predicates.add(cb.between(root.get("createTime"),userParam.getBeginCreateTime(),userParam.getEndCreateTime()));}if (StringUtils.isNotBlank(userParam.getAddressCity())) {//联表查询,利用root的join方法,根据关联关系表里面的字段进行查询。predicates.add(cb.equal(root.join("addressEntityList").get("addressCity"), userParam.getAddressCity()));}return query.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();}, pageable);}
}
//可以仔细体会上面这个案例,实际工作中应该大部分都是这种写法,就算扩展也是百变不离其中。
  • 我们再来看一个不常见的复杂查询的写法,来展示一下 CriteriaQuery 的用法(作者已经强烈不推荐了哦,和上面比起来太不优雅了)。
public List<MessageRequest> findByConditions(String name, Integer price, Integer stock) {  messageRequestRepository.findAll((Specification<MessageRequest>) (itemRoot, query, criteriaBuilder) -> {//这里用 List 存放多种查询条件,实现动态查询List<Predicate> predicatesList = new ArrayList<>();//name 模糊查询,like 语句if (name != null) {predicatesList.add(criteriaBuilder.and(criteriaBuilder.like(itemRoot.get("name"), "%" + name + "%")));}// itemPrice 小于等于 <= 语句if (price != null) {predicatesList.add(criteriaBuilder.and(criteriaBuilder.le(itemRoot.get("price"), price)));}//itemStock 大于等于 >= 语句if (stock != null) {predicatesList.add(criteriaBuilder.and(criteriaBuilder.ge(itemRoot.get("stock"), stock)));}//where() 拼接查询条件query.where(predicatesList.toArray(new Predicate[predicatesList.size()]));//返回通过 CriteriaQuery 拼装的 Predicatereturn query.getRestriction();});}
  • 而没有 Spring Data JPA 封装之前,如果想获得此三个对象 Root<T> root, CriteriaQuery<?> query, CriteriaBuilder criteriaBuilder,老式 Hibernate 的写法如下(PS:强烈不推荐哦,虽然现在也支持,只是让大家知道了解一下。):
@Autowired //导入entityManagerprivate EntityManager entityManager;
//创建CriteriaBuilder安全查询工厂,CriteriaBuilder是一个工厂对象,安全查询的开始.用于构建JPA安全查询.
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
//创建CriteriaQuery安全查询主语句
//CriteriaQuery对象必须在实体类型或嵌入式类型上的Criteria 查询上起作用。
CriteriaQuery<Item> query = criteriaBuilder.createQuery(Item.class);
//Root 定义查询的From子句中能出现的类型
Root<Item> itemRoot = query.from(Item.class);
  • 我们再来看一个利用 CriteriaQuery 例子,其实大家可以扩展一下思路,就是 Hibernate 那套在这里面都支持,不过作者还是建议代码越简单越好。
        List<UserSpuFavoriteEntity> result = userSpuFavoriteDao.findAll((Root<UserSpuFavoriteEntity> root, CriteriaQuery<?> query, CriteriaBuilder cb)->{query.where(cb.and(cb.equal(root.get("userName"), userName),cb.isFalse(root.get("isDelete"))));query.orderBy(cb.desc(root.get("updateTime")));return query.getRestriction();});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/496344.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

手机反编译java源码,Android反编译(一)之反编译JAVA源码

Android反编译(一)之反编译JAVA源码[目录]1、工具2、反编译步骤步骤1&#xff1a;把apk文件后缀名改为.zip步骤2&#xff1a;解压zip包得到classes.dex步骤3&#xff1a;将Dex反编译为Jar包(工具&#xff1a;dex2jar)命令: CMD>dex2jar.bat classes.dex步骤4&#xff1a;用j…

一文详解计算机视觉的广泛应用:网络压缩、视觉问答、可视化、风格迁移等

作者 | 张皓&#xff08;南京大学&#xff09;来源&#xff1a;人工智能头条丨公众号引言深度学习目前已成为发展最快、最令人兴奋的机器学习领域之一&#xff0c;许多卓有建树的论文已经发表&#xff0c;而且已有很多高质量的开源深度学习框架可供使用。然而&#xff0c;论文通…

[转]暴牛!全国女生录用老公统一考试试卷

全国女生录老公统一考试试卷①本试卷为全国女生招录老公统一考试试卷&#xff0c;各省(自治区、直辖市&#xff0c;计划单列市&#xff0c;不含港、澳、台地区)均须使用此卷&#xff0c;不得自行命题。②由于法律未规定同性婚姻合法&#xff0c;故报名参加考试者均须为男性。若…

Linux-进程、进程组、作业、会话、控制终端详解

From&#xff1a;http://www.cnblogs.com/JohnABC/p/4079669.html Linux进程优先级的处理--Linux进程的管理与调度(二十二)&#xff1a;http://blog.csdn.net/gatieme/article/details/51719208 进程 、进程组、会话、控制终端之间的关系&#xff1a;http://blog.csdn.net/y…

Spring Data JPA 从入门到精通~Specification工作中的一些扩展

Specification 工作中的一些扩展 我们在实际工作中会发现&#xff0c;如果上面的逻辑&#xff0c;简单重复写总感觉是不是可以抽出一些公用方法呢&#xff0c;此时引入一种工厂模式&#xff0c;帮我们做一些事情&#xff0c;可以让代码更加优雅。基于 JpaSpecificationExecuto…

用php编写xml,PHP 读取和编写 XML

什么是 XML&#xff1f;XML 是一种数据存储格式。它没有定义保存什么数据&#xff0c;也没有定义数据的格式。XML 只是定义了标记和这些标记的属性。格式良好的 XML 标记看起来像这样&#xff1a;代码如下:Jack HerringtonDOM读取 XML代码如下:$doc new DOMDocument();$doc-&g…

浅谈项目开发现状(一)

在现在的软件开发中&#xff0c;一些大的软件公司有充分的资金&#xff0c;所以他的公司人员组织架构能组成&#xff1a;需求分析团队&#xff08;为了更好的了解用户的完整需求&#xff09;--->研发团队&#xff08;通过计算机语言来实现用户需求&#xff09;&#xff0c;方…

波士顿咨询:2018最具创新力企业50强

来源&#xff1a;前瞻网在波士顿咨询公司评选的2018年最具创新力公司中&#xff0c;有11家公司——其中包括前10名中的7家——都是“数字原住民”&#xff0c;按定义也就是“数字创新者”。榜单上大多数公司已经将数字技术建立在他们的创新计划中。这一趋势在各个行业都很普遍&…

java 防止sql xxs注入,Java-JSP网站 防SQL注入,防XSS等攻击有什么好的处理办法?...

jsp 来防SQL注入&#xff0c;防XSS等攻击的话&#xff0c;首先要选择PreparedStatement来处理sql语句&#xff01;同时java后台还需要对页面中接受到的参数进行字符替换&#xff01;/*** 清除所有XSS攻击的字符串* 学来的&#xff01;分享&#xff01;*/public static String g…

Linux 线程

Linux 的多线程编程的高效开发经验&#xff1a;https://www.ibm.com/developerworks/cn/linux/l-cn-mthreadps/ linux线程的实现&#xff1a;http://www.cnblogs.com/zhaoyl/p/3620204.html 线程概念经典解析&#xff1a;http://blog.chinaunix.net/uid-29613952-id-421477…

Spring Data JPA 从入门到精通~JpaSpecificationExecutor实现原理

JpaSpecificationExecutor 实现原理 我们还是先通过开发工具&#xff0c;把关键的类添加到Diagram上面进行分析&#xff0c;如图&#xff1a; 我们通过上图可以看一下&#xff0c;前面介绍的几个类之间的关联关系。 SimpleJpaRepository 实现类中的关键源码如下&#xff1a; …

XML文档处理(树的应用)

1&#xff0e;问题陈述设计一个关于XML文档存取的类库&#xff0c;按树的方式处理XML文档&#xff0c;实现对树形文档进行一些基本操作的功能。2&#xff0e;基本要求内部要求&#xff1a;XML文档可一次全部读入内存后处理。至少设置文档类、XML元素类等。提供基本的树结构访问…

微信发布首份《移动支付时代的无人零售报告》

来源&#xff1a;爱范儿 作者&#xff1a;Panda3 月 30 日&#xff0c;微信支付行业运营总监白振杰在 2018 智慧无人零售大会上发布了《移动支付时代的无人零售行业报告》&#xff0c;报告首次结合中国百货商业协会权威调研和微信支付的数据分析能力&#xff0c;揭示了移动支…

mousemove事件java,three.js,补间相机和mousemove事件

我正在尝试使用three.js我正在使用补间移动相机&#xff0c;它工作得很好 . 但是&#xff0c;在动画结束时&#xff0c;相机会跳回到初始位置 .我发现mousemove事件导致了这种行为 . 我如何解决这个问题并保持补间动作和鼠标移动&#xff1f;我根据this example构建了我的three…

Spring Data JPA 从入门到精通~EntityManager介绍

EntityManager 介绍 我们前面已经无数次提到了&#xff0c;JPA 的默认 Repository 的实现类是 SimpleJpaRepository&#xff0c;而里面的具体实现就是调用的 EntityManager。对于 javax.persistence.EntityManager 通过源码&#xff0c;先来看下它主要给我们提供了哪几个方法&…

[转载]SQL SERVER 2008 阻止保存要求重新创建表的更改

微软新出了SQL Server 2008 数据库系统。在建完表后&#xff0c;如果要插入任意列&#xff0c;则提示&#xff0c;‘阻止保存要求重新创建表的更改’。 查了资料才明白如何解决这个问题。 当用户在在SQL Server 2008企业管理器中更改表结构时&#xff0c;必须要先删除原来的表&…

盘点《头号玩家》里的 VR 技术,现在就能造个 Oasis 出来

来源&#xff1a;沉浸感丨公众号 作者&#xff1a; 刘芳平由史蒂文斯皮尔伯格导演的科幻电影《头号玩家》&#xff08;Ready One Player&#xff09;于 3 月 30 日在中国大陆上映。首个周末便收获广泛好评&#xff0c;登上豆瓣电影本周口碑榜第一名&#xff0c;截止 31 日晚积…

find()matlab,Matlab 之 find()函数

当我第一次用matlab语言编写一个工程项目时&#xff0c;发现自己编写的脚本里循环特别多&#xff0c;导致编程效率很低&#xff0c;这让我特别苦恼。有一次导师让我阅读他编写的一个Matlab脚本&#xff0c;并按照新要求对其进行更改。我发现脚本里多次用到find()函数&#xff0…

Spring Data JPA 从入门到精通~自定义实现Repository

EntityManager 的获取方式 我们既然要自定义&#xff0c;首先讲一下 EntityManager 的两种获取方式。 1. 通过 PersistenceContext 注解。 通过将 PersistenceContext 注解标注在 EntityManager 类型的字段上&#xff0c;这样得到的 EntityManager 就是容器管理的 EntityMan…

一图看懂阿里云IoT战略

来源&#xff1a;云栖社区从万物互联到万物智联&#xff0c;离不开“无处不在的计算”。阿里云IoT在云边端部署了可协同的计算&#xff0c;基于物联网使能平台联合开发者、芯片模组厂商、行业合作伙伴等在城市、生活、汽车、制造四大领域已完成深度布局&#xff0c;即一朵云、两…