您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Java使OneToOne关系变得懒惰

Java使OneToOne关系变得懒惰

首先,对KLE的答案进行一些澄清:

无约束(可为空)的一对一关联是没有字节码检测就无法代理的唯一关联。原因是所有者实体必须知道关联属性应包含代理对象还是NULL,并且由于通常是通过共享PK进行一对一映射,因此无法通过查看其基表的列来确定该属性。无论如何,必须急切地获取代理,使其毫无意义。这是更详细的说明。

多对一关联(显然是一对多)不受此问题的困扰。所有者实体可以轻松地检查其自己的FK(如果是一对多,则最初会创建空集合代理并按需填充),因此关联可以很懒。

用一对多替换一对一几乎不是一个好主意。你可以用唯一的多对一替换它,但是还有其他(可能更好)的选择。

Rob H.有一个有效的观点,但是根据你的模型,你可能无法实现它(例如,如果一对一关联可以为空)。

现在,就原始问题而言:

A)@ManyToOne(fetch=FetchType.LAZY)应该工作正常。你确定查询本身不会覆盖它吗?可以join fetchHQL中指定和/或通过Criteria API显式设置获取模式,这将优先于类注释。如果不是这种情况,但你仍然遇到问题,请发布你的课程,查询生成sql,以进行更多的即时对话。

B)@OneToOne比较棘手。如果绝对不能为空,请遵循Rob H.的建议并将其指定为:

@OneToOne(optional = false, fetch = FetchType.LAZY)

否则,如果你可以更改数据库(向所有者表添加外键列),请进行更改并将其映射为“ joined”:

@OneToOne(fetch = FetchType.LAZY)
@JoinColumn(name="other_entity_fk")
public OtherEntity getOther()

并在OtherEntity中:

@OneToOne(mappedBy = "other")
public OwnerEntity getOwner()

如果你不能做到这一点(并且不能随心所欲地获取),则字节码检测是你唯一的选择。但是,我必须同意CPerkins的意见-如果你有80 岁!由于渴望OneToOne协会而加入,那么你遇到了更大的问题

java 2022/1/1 18:18:49 有410人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶