繁体   English   中英

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

[英]What is the best way to limit results using a DetachedCriteria of Hibernate in Java?

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

附加信息:

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

这就是我在做的方式,你必须将你的结果包装成执行块。 以下示例中的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;

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

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

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

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

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

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

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM