web-dev-qa-db-ja.com

休止状態の基準でoneToMany結合テーブルをどのように注文しますか

子猫へのoneToManyマッピングを持つクラスMotherがあるとします

@Entity
@org.hibernate.annotations.Entity(dynamicUpdate = true)
@Table(name = "Mother")

.....

@OneToMany(fetch = FetchType.LAZY, targetEntity=Kittens.class, cascade=CascadeType.ALL)
@JoinColumn(name="motherId")
private List<Kittens> kittens;

リストを提供するために基準Apiを使用しています

Criteria criteria = this.getSession().createCriteria(Mother.class);
Criterion MotherType = Restrictions.eq("type", "domesticated");
criteria.add(MotherType)
.addOrder(Order.asc("motherName"))
.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY)
.setFetchMode("kittens", FetchMode.JOIN)
// .addOrder(Order.asc("kittens.kittenName"));
List test = criteria.list();

子猫フィールドkittenNameの順序を追加しようとするまで正常に動作します

また、子APIの@OneToMany(... etc)の下に@OrderBy(value = "kittenName")アノテーションを追加しようとしました。これは、条件APIを使用し、この順序がSQLの他の順序ステートメントに先行するまで正常に動作します。

どんな助けでも事前に乾杯...

35
jaseFace

追加する必要があります @javax.persistence.OrderBykittensリストへの注釈。

@OneToMany(fetch = FetchType.LAZY,
           targetEntity=Kittens.class,
           cascade=CascadeType.ALL)
@JoinColumn(name="motherId")
@OrderBy("kittenName")
private List<Kittens> kittens;

@見る

69
Ralph