5

我们正在针对 Oracle 数据库使用 Hibernate Annotations 3.4.0GA 和 Hibernate Core 3.3.2.GA(也称为当前稳定版本)

我们有一个 base=1 的一对多映射,它工作了很长时间,但上周我们在数据库中发现了一些索引列包含值 0 的条目,这导致了各种问题。

所以我的问题是:有没有人知道将值 0 放入一对多关系的索引列中的方法,当它被映射为 base=1 时?可能与使用泛型或 MappedSuperclass 有关。

请注意,代码相当复杂,因为也涉及到继承。

以下是课程的相关部分:

// SuperClass of the One side
@MappedSuperclass
public abstract class AbstractReihung<Tp, Tw, Te extends AbstractReihungElement<Tp, Tw>>
{
  @OneToMany(cascade = CascadeType.ALL)
  @Cascade(
  {
      org.hibernate.annotations.CascadeType.ALL,
      org.hibernate.annotations.CascadeType.DELETE_ORPHAN
  })
  @JoinColumn(name = "parent_id", nullable = false)
  @IndexColumn(name = "position", base = 1, nullable = false)
  private List<Te> elements = new ArrayList<Te>();
}

// Super Class of the Many side
@MappedSuperclass
public abstract class AbstractReihungElement<Tp, Tw> extends AbstractDbObject
{
  @ManyToOne
  @JoinColumn(name = "parent_id", insertable = false, updatable = false, nullable = false)
  private Tp parent;

  @Column(name = "position", insertable = false, updatable = false, nullable = false)
  private int position;
}

实际的类继承自这些并为类型参数提供具体的类。它们被映射为实体。他们还指定 id 和 version 列以及大量其他属性和引用,但与手头的映射无关。

4

1 回答 1

2

我知道已经快两年了,但我在寻找相同问题的解决方案时偶然发现了这一点。我们通过 xml 文件使用 hbm,所以我不太确定这是否会有所帮助。在我们的例子中,问题是反向映射。如果对列表(和索引)的控制在列表元素方面(“许多”),就像你的情况一样,我们就有问题了。向上移动解决了这个问题。不知道这是如何使用注释完成的。

错误的另一个来源可能是您在 AbstractReihung 对象上实际设置了“元素”。Hibernate 使用代理对象来延迟加载属性。如果你设置一个全新的集合而不是修改现有的集合,你会覆盖代理对象。

于 2012-01-19T14:08:06.760 回答