13

我正在使用 Hibernate 3.2,并使用条件来构建查询。我想为多对一关联添加和“排序”,但我不知道如何做到这一点。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

我已经尝试过 criteria.addOrder("assnName.propertyName") 但它不起作用。我知道它可以用于普通属性。我错过了什么吗?

4

2 回答 2

23

好的,找到答案了。我尝试了一些我认为行不通的方法,但令我惊讶的是,我做到了。我正在尝试这个:

Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class);

criteria.addOrder(Order.asc("assnName.propertyName"))

但实际起作用的是:

Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class);
Criteria assnCrit = criteria.createCriteria("assnName");

assnCrit.addOrder(Order.asc("propertyName"));

我假设 addOrder() 方法仅可用于主要标准,而不能用于任何关联标准。

于 2009-05-15T20:47:48.487 回答
14

我遇到了同样的问题,也可以这样解决:

Criteria criteria = super.getSession().createCriteria(WipDiscreteJob.class)
  .createAlias("assnName","a")
  .addOrder(Order.asc("a.propertyName"));

createAlias 让您的标准植根于您的原始实体(在本例中为 WipDiscreteJob.class),以便您可以在需要时继续构建标准(例如,如果您需要原始实体的第二个属性订单) .

于 2010-04-09T21:54:09.100 回答