@OrderColumn, @OneToMany & столбец нулевого индекса для коллекции

Я пытаюсь создать родительские дочерние таблицы, в которых сохраняется порядок. Пример 7.8 из документации Hibernate показывает, как это сделать:

@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 getOrders() { return orders; }
   public void setOrders(List orders) { this.orders = orders; }
   private List 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 children;
}

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

from: https: // hibernate.onjira.com/browse/HHH-5390

Может быть, я слишком плотный, но я не вижу разницы между этими двумя примерами. Один:

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

Другой:

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

И, конечно, я не понял, как заставить работать OrderColumn. Кто-нибудь знает, почему один из этих примеров верен, а другой нет?

10
задан Mark 21 July 2011 в 14:25
поделиться