编程语言
首页 > 编程语言> > java-Hibernate自引用实体为非null列

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