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实战》——汪云飞著

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容