您如何在休眠条件中订购 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 连接表的主要内容,如果未能解决你的问题,请参考以下文章