jpa多表联查动态_Spring Data JPA实现动态多表关联查询

在面向关系型数据库(例如:MySQL)的查询中,动态的、多表关联的查询属于比较复杂的情况。所以,我们只要掌握了这种复杂的查询,当面对其他查询情况时,就能做到胸有成竹。

在java工程中,目前我所了解到,有两种方法能实现这种查询。第一种是“手动拼接sql语句”,如果你对sql语句很熟悉,那么这种方法上手快,很灵活,但缺点是对新手不太友好,易读性差,另外容易因为手误写错语句;第二种方法就是通过Spring Data JPA来实现了,这种方法上手略微有些难度,但完全由java方法实现,所以可读性好,不容易写错,代码“优美”。

之前我只对Spring Data JPA的动态查询比较熟悉,这次是将多表和动态结合起来,“完美”!

一、概念介绍

JPA:Java Persistence API,仅是规范,主要实现有Hibernate、EclipseLink和OpenJPA等。

Spring Data JPA:是Spring Data的一个子项目,提供基于JPA的Repository极大地减少JPA作为数据库访问方案的代码量。

Specification([ˌspesɪfɪˈkeɪʃn],规格,说明书):JPA提供了基于准则查询的方式,即Criteria查询( [kraɪ'tɪərɪə],标准,准则)。而Spring Data JPA提供了一个Specification接口让我们可以更方便地构造准则查询,Specification接口定义了一个toPredicate( [ˈpredɪkət],断言,断定)方法用来构造查询条件。

二、三张表的介绍

grp表——GrpEntity、grp_host表——GrpHostEntity、host表——HostEntity

grp表与host表是多对多,grp_host表则是两者的关系表。

GrpEntity

HostEntity,注解里提到关联表:grp_host

三、查询相关代码的介绍

我们的需求是传入grpId,查询host list,当然,也有可能传入host name进行模糊查询,以及其他筛选条件。

1、创建Repository接口

正如我前面说到的,Spring Data JPA提供了一个强大的Repository来减少代码量,所以可以称这个Repository是查询的核心,我们创建一个接口来继承JpaRespository,这样我们这个接口就拥有了查询的能力;继承JpaSpecificationExecutor是为了下一步构造动态和多表关联的查询。如图所示:

JpaRepository

2、编写动态查询(敲黑板,划重点)

构造查询条件的方法

14行和15行就是多表查询(通过grp表的id来查询对应的host list),“grpEntityList”是HostEntity中的属性。默认是JoinType.INNER(内连接 inner join),也可以是JoinType.LEFT(左外连接 left join)。

17行和18行:如果传了host name,则对host name进行模糊查询。

3、调用查询方法(分页)

19行:创建PageRequest,实现分页。

24行:调用刚才写的本类中的查询方法,其中findAll是继承自JpaRepository的方法。

参考资料:

《Spring Boot实战》——汪云飞著

顺便分享一下我自己写的电影搜索网站哈,搜冷门电影有奇效。有兴趣的伙伴可以瞧一瞧>>>>>>>>>>海上渔夫—看电影,看我所选

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值