如何通过Hibernate/JPA的Proxy实现父子关联的实体插入?


执行更多的SQL总是性能损失。重要的是努力尽可能地减少它们的数量,并且依赖于指向引用是一种易于使用的优化方式。
当一个带有指向其父实体的子实体持久化并时,Proxy可能很有用。在这种情况下,从数据库中获取父实体(执行SELECT语句)是一种性能损失和无意义的操作。Hibernate可以为未初始化的Proxy设置外键值。
关键点:

  • 依靠 EntityManagergetReference()
  • 在Spring中,使用 JpaRepositorygetOne()
  • 在本例中使用,在Hibernate中使用 load()
  • 在这里案例源码中,我们有两个实体:Tournament并且TennisPlayer,一个tournament 可以有多个TennisPlayer(@OneToMany)。
  • 我们通过一个Proxy(这不会触发SELECT)获取tournament ,我们创建一个新的TennisPlayer并设置Proxy为该球员的tournament ,并且我们保存该球员(这将I触发tennis_player表中的NSERT)

输出样本:
  • 控制台输出将显示只有一个INSERT被触发,没有SELECT

源代码可以在这里找到