[英]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.