解决 JPA OneToOne 关系中的延迟加载问题
此查询涉及由于 Hibernate 中的联接数量过多而导致性能缓慢的应用程序询问。尽管用 FetchType.LAZY 注解了 @OneToOne 和 @ManyToOne,但延迟加载似乎并没有生效。
问题根源
问题出在深层实体之间的一对一和多对一关系的层次结构。虽然 ManyToMany 和 OneToMany 关系很容易变得惰性,但对于某些类型的 OneToOne 关联却并非如此。
解决方案
A.可空的一对一关系(无约束)
无约束的一对一关联(其中关联的属性可以为空)在没有字节码检测的情况下无法代理。这是因为所有者实体需要知道关联是否包含代理或 null,这不能仅根据基表的列来确定。
B.不可为空的一对一关系
对于不可为空的一对一关联,可以使用以下选项:
将关联映射为连接关系,向所有者表添加外键列:
@OneToOne(fetch = FetchType.LAZY) @JoinColumn(name="other_entity_fk") public OtherEntity getOther()
C. ManyToOne 关系
ManyToOne 关系可以无限制地变得惰性:@ManyToOne(fetch=FetchType.LAZY)。但是,请确保此注释不会在查询本身中被覆盖。
注意事项
如果急切加载 OneToOne 关联会导致严重的性能问题,则更广泛的设计缺陷应该研究数据模型。作为最后的手段,字节码检测可能是必要的。
实现说明
以上是为什么我的 JPA @OneToOne 延迟加载不工作?的详细内容。更多信息请关注PHP中文网其他相关文章!