在Java中使用Hibernate的DetachedCriteria来限制结果的最佳方法是什么?

时间:2012-07-16 15:50:12

标签: java hibernate orm detachedcriteria

我在Java中使用Hibernate 3.5.6-Final。由于我无法访问Hibernate Session,因此我使用了DetachedCriteria。所以,我想知道限制DetachedCriteria 的结果的最佳方法是什么(在我的情况下,我只希望获得第一行)。

其他信息:

Criteria类有一些实现此目的的方法,如setMaxResults(int maxResults)setFirstResult(int firstResult),但DetachedCriteria没有。同样,我不能使用Criteria,因为我无法访问Hibernate的Session。

6 个答案:

答案 0 :(得分:10)

我正在这样做,你必须将你的结果包装成执行块。 以下示例中的EntityMAnager是org.springframework.orm.hibernate3.HibernateOperations对象:

final DetachedCriteria criteria = DetachedCriteria.forClass(ActivePropertyView.class);
criteria.add(Restrictions.eq("featured", true));
List<ActivePropertyView> result = entityManager.execute(
     new HibernateCallback<List<ActivePropertyView>>() {
         @Override
         public List<ActivePropertyView> doInHibernate(Session session) 
                                         throws HibernateException,SQLException {
                 return criteria.getExecutableCriteria(session).setMaxResults(5).list();
         }
     });
return result;

答案 1 :(得分:5)

您可以使用Restrictions.sqlRestriction()向DetachedCriteria添加纯SQL表达式。试试这个:

DetachedCriteria criteria = DetachedCriteria.forClass(Domain.class)
  .add(Restrictions.sqlRestriction("LIMIT 1"));

答案 2 :(得分:3)

如果您使用的是休眠模板,则会有findByCriteria(criteria, firstResult, maxResults)。不鼓励使用模板,但对于那些使用遗留代码的人来说,这是可用的。

答案 3 :(得分:2)

如果我正在读取javadoc,那么在最终将DetachedCriteria转换为真正的Criteria(当你有一个Session)时,你不能限制

答案 4 :(得分:0)

扩展yorkw的答案,Oracle的等价物是:

DetachedCriteria criteria = DetachedCriteria.forClass(Domain.class)
  .add(Restrictions.sqlRestriction("rownum < 1"));

它会将行限制添加到子查询中的“where”子句。

答案 5 :(得分:-1)

detachedCriteria.getExecutableCriteria(getSession()).setMaxResults(1);