Dojo
最新
最佳
搜索
订阅
解道Jdon
架构设计
领域驱动
DDD介绍
DDD专辑
战略建模
领域语言UL
领域事件
商业分析
工作流BPM
规则引擎
架构师观点
数据工程
产品经理
系统思维
微服务
微服务介绍
微服务专辑
模块化设计
SOA
API设计
clean架构
SpringBoot
分布式事务
分布式架构
Kubernetes
DevOps
编程设计
GoF设计模式
模式专辑
面向对象
函数式编程
编程语言比较
编程工具比较
形式逻辑
前端编程
Reactive编程
Jdon框架
Rust语言
人工智能
Web3
模因梗
幽默梗
程序员吐槽
面试技巧
Java入门
数字化转型
认知偏差
道德经
更多话题
如何通过Hibernate/JPA的Proxy实现父子关联的实体插入?
19-01-30
banq
执行更多的SQL总是性能损失。重要的是努力尽可能地减少它们的数量,并且依赖于指向引用是一种易于使用的优化方式。
当一个带有指向其父实体的子实体持久化并时,Proxy可能很有用。在这种情况下,从数据库中获取父实体(执行SELECT语句)是一种性能损失和无意义的操作。Hibernate可以为未初始化的Proxy设置外键值。
关键点:
依靠 EntityManager
getReference
()
在Spring中,使用 JpaRepository
getOne
()
在本例中使用,在Hibernate中使用 load()
在这里案例源码中,我们有两个实体:Tournament并且TennisPlayer,一个tournament 可以有多个TennisPlayer(@
OneToMany
)。
我们通过一个Proxy(这不会触发SELECT)获取tournament ,我们创建一个新的TennisPlayer并设置Proxy为该球员的tournament ,并且我们保存该球员(这将I触发tennis_player表中的NSERT)
输出样本:
控制台输出将显示只有一个INSERT被触发,没有SELECT
源代码可以在
这里
找到
1
hibernate
jpa持久层框架
SpringBoot框架
数据关联模型