您如何在休眠条件中订购 oneToMany 连接表

Posted

技术标签:

【中文标题】您如何在休眠条件中订购 oneToMany 连接表【英文标题】:How do you order a oneToMany join table in hibernate criteria 【发布时间】:2011-07-30 10:09:46 【问题描述】:

假设我有一个类 Mother 与 Kittens 的 oneToMany 映射

@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 的顺序之前工作正常

我还尝试在 Kitten @OneToMany(...etc ) 下添加 @OrderBy(value="kittenName") 注释,在您使用标准 API 之前它工作正常,并且此订单将在任何其他订单语句之前sql。

提前欢呼任何帮助...

【问题讨论】:

【参考方案1】:

您需要将@javax.persistence.OrderBy 注释添加到您的kittens 列表中。

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

@见

Hibernate 注释参考指南 Chapter 2.2.5. Mapping entity associations/relationships 子章节 2.2.5.3.4。索引集合(列表、地图)

【讨论】:

嗨拉尔夫。我已经尝试过了,但是生成的 sql 将 kittenName 顺序放在 MotherName 顺序之前。即选择...按kittens.kittenName asc、mother.motherName asc 排序。而且我正在尝试按mother.motherName asc,kittens.kittenName asc 来实现订单。谢谢 @user456147:我好像不太明白你想做什么?加载什么,按什么顺序?什么不能按你的意愿工作? 抱歉,如果我没有说清楚。我想按 MotherName 然后 KittenName 订购。如果我将 OrderBy 放在 Kitten 实体上,则顺序相反。 @user456147:“我想先按 MotherName 再按 KittenName。”? - 你的意思是,“我想按妈妈的名字订购小猫”? 嗨,拉尔夫最终使用了 criteria.createAlias("genres", "genreAlias", CriteriaSpecification.INNER_JOIN) 而不是 setFetchMode(... SELECT) 你允许我按照你在你的建议中设置顺序用@OrderBy 回答。干杯。

以上是关于您如何在休眠条件中订购 oneToMany 连接表的主要内容,如果未能解决你的问题,请参考以下文章

休眠 @OneToMany 没有单独的连接表

非主键之间的休眠关系OneToMany

休眠条件排序依据

@OneToMany 与休眠中的关联表

非冗余休眠列表映射 (OneToMany)

我在@OneToMany 休眠映射中遇到错误?