gpt4 book ai didi

java - @OrderColumn、@OneToMany & 用于集合的空索引列

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:54:29 26 4
gpt4 key购买 nike

我正在尝试创建保留顺序的父子表。 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 工作。有谁知道为什么这些示例中的一个有效而另一个无效?

最佳答案

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

另见 discussion关于相同的问题和 3.5 的解决方法。


更新

显然它仍然不受支持,并且存在一个文档错误,如 HHH-5732 所述.我从HHH-5390想到分配给它的人(拥有 HHH-5390 的人)已同意修复它。但尚不清楚它是否以及何时会发生。

关于java - @OrderColumn、@OneToMany & 用于集合的空索引列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6763329/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com