我在Java中使用Hibernate 3.5.6-Final。由于我无法访问Hibernate Session,因此我使用了DetachedCriteria。所以,我想知道限制DetachedCriteria 的结果的最佳方法是什么(在我的情况下,我只希望获得第一行)。
其他信息:
Criteria类有一些实现此目的的方法,如setMaxResults(int maxResults)或setFirstResult(int firstResult),但DetachedCriteria没有。同样,我不能使用Criteria,因为我无法访问Hibernate的Session。
答案 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);