java - 当引用的非外键列为 null 时,Hibernate 用 null 初始化一对多集
问题描述
我在 EntityA 和 EntityB 之间有一个双向的一对多关系。该关系不是基于外键,而是实体需要与linking_field
数据库中的唯一链接。相关映射:
实体A:
@Id
private Long id;
@OneToMany(mappedBy = "entityA")
private Set<EntityB> children = new HashSet<>();
@Column(name = "linking_field")
private String linkingField;
实体B:
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "entity_a_id", referencedColumnName = "linking_field", nullable = false)
private EntityA entityA;
现在,让我们想象一下 EntityB 的表为空的情况。问题是,当我尝试使用显式es字段的Spring Data 存储库方法获取null
在列中有值的entityA 时,该字段被初始化为. 但是,设置 时并非如此 - 然后 Hibernate 将空分配给,这对我来说是一种期望的行为。有什么办法可以克服吗?linking_field
JOIN FETCH
children
children
null
linking_field
PersistentSet
children
EntityA 有linkingField == null
:
EntityA entityA = entityARepository.findByIdWithChildren(entityAId);
entityA.getChildren(); // null
EntityA 有linkingField != null
:
EntityA entityA = entityARepository.findByIdWithChildren(entityAId);
entityA.getChildren(); // empty Set -> desirable
提前致谢。
解决方案
显然,不幸的是,这就是 Hibernate 的工作方式。我已经调试了代码,这是来自 HibernateCollectionType
类的相关部分:
private Object resolveKey(Serializable key, SharedSessionContractImplementor session, Object owner, Boolean overridingEager) {
// if (key==null) throw new AssertionFailure("owner identifier unknown when re-assembling
// collection reference");
return key == null ? null : // TODO: can this case really occur??
getCollection( key, session, owner, overridingEager );
}
在我的例子中,key
参数为空,所以事实证明他们简单地用空覆盖了整个集合。
推荐阅读
- sql - SQL 存储过程超时
- django - 将 React 流量重定向到开发中的 Django REST
- android - 在哪里/如何确定聊天消息是发送还是接收(android)
- azure - 如何从 luis 读取/访问情绪分析结果
- c# - 使用 linq any 检查列表中是否包含
- python - Pandas - 在多列上使用`.rolling()`
- sql - SQL server 中的 Oracle Connect_is_leaf 类似
- mysql - 在mysql数据库中查找最长的连续系列
- wso2 - wso2 5.0.0 jms activemq consummer.exclusive
- sql - 保存查询结果而不将其附加到 PostgreSQL 中的现有表中