加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-15 05:20:31 所属栏目:Java 来源:网络整理
导读:我在 Java中使用Hibernate 3.5.6-Final.由于我无法访问Hibernate Session,我使用的是 DetachedCriteria.所以,我想知道限制DetachedCriteria结果的最佳方法是什么(在我的情况下,我想只得到第一个)行). 附加信息: Criteria类有一些方法可以实现这一点,如setMa
我在 Java中使用Hibernate 3.5.6-Final.由于我无法访问Hibernate Session,我使用的是 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;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读