Gar*_*art 13 hibernate associations sql-order-by
我正在使用Hibernate 3.2,并使用条件来构建查询.我想为多对一关联添加"order by",但我不知道如何做到这一点.我想,Hibernate查询最终看起来像这样:
select t1.a, t1.b, t1.c, t2.dd, t2.ee
from t1
inner join t2 on t1.a = t2.aa
order by t2.dd <-- need to add this
Run Code Online (Sandbox Code Playgroud)
我已经尝试过criteria.addOrder("assnName.propertyName"),但它不起作用.我知道它可以用于普通属性.我错过了什么吗?
Gar*_*art 23
好的,找到了答案.我尝试了一些我认为不会起作用的东西,但令我惊讶的是.我在尝试这个:
Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class);
criteria.addOrder(Order.asc("assnName.propertyName"))
Run Code Online (Sandbox Code Playgroud)
但实际工作的是:
Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class);
Criteria assnCrit = criteria.createCriteria("assnName");
assnCrit.addOrder(Order.asc("propertyName"));
Run Code Online (Sandbox Code Playgroud)
我假设addOrder()方法只能用于主要标准,而不能用于任何关联标准.
Mar*_*elo 14
我遇到了同样的问题,它也可以像这样解决:
Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class)
.createAlias("assnName","a")
.addOrder(Order.asc("a.propertyName"));
Run Code Online (Sandbox Code Playgroud)
createAlias允许您根据原始实体(在本例中为WipDiscreteJob.class)保留您的条件,以便您可以在需要时继续构建条件(例如,如果您需要来自原始实体的属性的第二个订单) .
| 归档时间: |
|
| 查看次数: |
10297 次 |
| 最近记录: |