我正在尝试创建保留订单的父子表。 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工作。有没有人知道为什么其中一个例子有效而另一个不是?
答案 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时效果更好。