@OrderColumn,@ OneToMany&用于集合的null索引列

时间:2011-07-20 14:11:28

标签: java hibernate jpa jpa-2.0

我正在尝试创建保留订单的父子表。 Hibernate文档中的示例7.8显示了如何执行此操作:

@Entity
public class Customer {
   @Id @GeneratedValue public Integer getId() { return id; }
   public void setId(Integer id) { this.id = id; }
   private Integer id;

   @OneToMany(mappedBy="customer")
   @OrderColumn(name="orders_index")
   public List<Order> getOrders() { return orders; }
   public void setOrders(List<Order> orders) { this.orders = orders; }
   private List<Order> orders;
}

@Entity
public class Order {
   @Id @GeneratedValue public Integer getId() { return id; }
   public void setId(Integer id) { this.id = id; }
   private Integer id;

   public String getNumber() { return number; }
   public void setNumber(String number) { this.number = number; }
   private String number;

   @ManyToOne
   public Customer getCustomer() { return customer; }
   public void setCustomer(Customer customer) { this.customer = customer; }
   private Customer number;
}

来自http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/collections.html#collections-indexed

当我尝试这个时,我收到一个错误: 集合的空索引列

有Hibernate问题描述了这个问题并提供了一个无效的例子,但它明确地说我上面给出的文档中的例子是有效的。

@Entity
public class Parent {
    @OneToMany(mappedBy="parent")
    @OrderColumn(name="order")
    private List<Child> children;
}

@Entity
public class Child {
    @ManyToOne
    private Parent parent;
}

来自:https://hibernate.onjira.com/browse/HHH-5390

也许我是在密集,但我没有看到这两个例子之间的区别。一个是:

@OneToMany(mappedBy="customer")
@OrderColumn(name="orders_index")

另一个是:

@OneToMany(mappedBy="parent")
@OrderColumn(name="order")

当然,我还没有弄清楚如何让OrderColumn工作。有没有人知道为什么其中一个例子有效而另一个不是?

5 个答案:

答案 0 :(得分:7)

该bug指的是Hibernate 3.5.3,而文档指的是Hibernate 3.6。我从评论中了解到问题HHH-5390已经解决。你使用哪个版本的Hibernate? 请注意,您必须在@OrderCoulumn中有一个具有指定名称的列。

另请参阅此discussion有关同一问题以及3.5的情况下的解决方法。


更新

显然它仍然不受支持,并且HHH-5732描述了文档错误。我从HHH-5390开始认为,被分配的人(拥有HHH-5390的人)同意解决它。但目前尚不清楚它是否以及何时会发生。

答案 1 :(得分:3)

对我来说,重点是将@OrderColumn中声明的列设置为NOT NULL并使用默认值0

答案 2 :(得分:2)

做这样的事情:

@Entity
class Parent {

    @OneToMany
    @IndexColumn(name = "index_column")
    List<Child> children;
}

@Entity
class Child {

    @ManyToOne
    Parent parent;
    @Column(name = "index_column")
    Integer index;

    @PrePersist
    @PreUpdate
    private void prepareIndex() {
        if (parent != null) {
            index = parent.children.indexOf(this);
        }
    }
}

答案 3 :(得分:1)

莫因,

hibernate.core 5.1.4 final 上出现同样的问题。在标记Set上使用HashSet@OrderColumn(就像奥古斯丁所说的那样)可以解决问题。

答案 4 :(得分:0)

也许这些可以帮到你:

对于带有标记@IndexColumn的旧版 hibernate(3.5.6),我遇到同样的问题,并找到一个好的非侵入性解决方法:尝试更改{{1} } List<Message>对象并使用Set<Message>代替HashSet。 似乎旧的Hibernate版本在使用Sets时效果更好。

祝你好运!