java-Hibernate自引用实体为非null列
作者:互联网
我正在使用Hibernate 5和Spring 3.2.4.我正在设计一个User实体,我想在其中包含对创建该实体的用户的引用-因此是一个自我引用.自我引用本身并不太成问题,但我想将字段指定为非null.这可能吗?如果该字段为非null,因为该引用实体不存在,该如何在数据库中创建第一个条目?
例如:
@Entity
public class User {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private Long User.id;
@NotNull
private String username;
private String password;
@NotNull
private User user;
// getters and setters omitted for brevity
}
如果我尝试:
User u = new User();
u.setUsername("username");
u.setCreatedBy(u);
并尝试坚持你,我得到以下错误信息:
Caused by: org.hibernate.TransientPropertyValueException: Not-null property references a transient value - transient instance must be saved before current operation: com.domain.User.createdBy -> com.domain.User
我了解到Hibernate抱怨它无法引用瞬时实例(即:u),但是除非我拥有可以引用的非null用户,否则我无法持久化u.但是在一个空的数据库中,没有这样的条目.
这种配置不可能吗?还是有办法解决?
解决方法:
我不理解这个Roo注释,我不使用Hibernate特定的注释,仅使用JPA.我自己引用没有任何问题.但我对您有一些提示:
>如前所述,使用@ManyToOne批注.
> AFAIK,@ NotNull批注(或@Column中的可为空字段)不影响映射,仅影响DDL生成.我不使用从域模型生成DDL的方式,也从未指定此方式.相反,我使用@ManyToOne的可选字段.
>您使用哪种标识符生成策略?如果是自动递增,则不能使用NOT NULL约束进行自引用.因此,要么使用基于序列的标识符生成器,要么删除约束.我会先使用.
>如前所述,当您具有NOT NULL约束时,请将@ManyToOne的可选字段设置为false.否则,Hibernate将尝试进行两个查询:插入createdBy_id设置为NULL的对象,然后更新createdBy_id.并且第一个查询在启用NOT NULL约束的情况下失败.
标签:jpa,hibernate,persistence,hibernate-5-x,java 来源: https://codeday.me/bug/20191122/2059710.html