4

尝试将父类中的 ID 保存到子类中时,我不断收到错误消息“错误 - 字段 'parent_id' 没有默认值”

我尝试了所有类型的映射。我正在使用注释。

对此的任何帮助将不胜感激

家长:

      @Id
      @Column(name="id")
      @GeneratedValue(strategy=GenerationType.AUTO)
      private long id;
      @Column(name="description")
      private String description;
      @OneToMany
      @Cascade(value= {org.hibernate.annotations.CascadeType.SAVE_UPDATE, org.hibernate.annotations.CascadeType.DELETE})
      @JoinColumn(name="parent_id")
      private List<Child> children;

孩子:

  @Id
  @Column(name="id")
  @GeneratedValue(strategy=GenerationType.AUTO)
  private long id;
  @Column(name="description")
  private String description;

谢谢。

4

5 回答 5

19

后期添加,以防有人遇到同样的问题。

这里的实体,当使用 Hibernate 4.1.8 持久化时,级联FieldChange实体,但不会填充连接列:

@Entity
public class Event {

    //ID and other fields here

    @OneToMany(cascade = CascadeType.ALL, orphanRemoval = true)
    @JoinColumn(name = "event_id")
    private List<FieldChange<?>> fields = new ArrayList<FieldChange<?>>();

 }

插入语句既不设置event_id列,也不在事后更新插入的实体 -event_id保持为空并且关系丢失。

但是,如果@JoinColumn定义更改如下:

@JoinColumn(name = "event_id", nullable = false)

,然后插入语句包含event_id应有的列,一切都很好。

这可能只是这个特定版本的 Hibernate 中的回归,但也许它可以帮助某人。

于 2012-11-22T15:30:10.883 回答
8

在您的情况下,JPA 提供程序将子对象与其父对象持久化,对数据库执行至少三个查询。前两个自己持久化对象。最后一个更新子对象,外键引用父对象。第二个查询失败,因为您在外键列上有一个 NOT NULL 约束。你有三个选择:

  1. 删除子实体中外键的 NOT NULL 约束
  2. 使用双向关系
  3. 将 JPA 提供程序更改为支持此类情况的提供程序。
于 2014-06-10T15:06:02.657 回答
6

您在其他地方一定有问题,因为这些映射将按原样工作。他们可能会更好,但他们会工作。具体来说,所有@Column注释都是多余和不必要的,并且正如 non sequitor 指出的那样,您应该使用 JPA 的 cascade 属性@OneToMany而不是 Hibernate 的@Cascade。我用您发布的内容的清理版本创建了一个可运行的示例。如果你有 git 和 maven,你可以运行它:

git clone git://github.com/zzantozz/testbed tmp
cd tmp
mvn -q compile exec:java \
    -Dexec.mainClass=rds.hibernate.UnidirectionalManyToOneJoinColumn \
    -pl hibernate-unidirectional-one-to-many-with-join-column

它创建一个有两个孩子的父级,保存它们,然后加载它们并打印出图形。输出是:

Creating parent with two children
Loading saved parent
Parent{description='parent', children=[Child{description='child 2'}, Child{description='child 1'}]}
于 2011-08-14T03:33:08.910 回答
1

更改您@OneToMany@OneToMany(cascade=CascadeType.ALL)使用 JPA 而不是 Hibernate 扩展

于 2009-11-07T05:21:53.977 回答
0

我的猜测是@JoinColumn annotation需要referencedColumnName分配。

@JoinColumn(name = "parent_id", referencedColumnName = "id")
于 2010-07-23T15:21:00.880 回答