执行更多的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
源代码可以在 这里
找到
原文
https://www.jdon.com/51630