使用spring getHibernateTemplate,如何获取用户列表并限制结果集? [英] With springs getHibernateTemplate, how can I get a list of users and limit the result set?

查看:143
本文介绍了使用spring getHibernateTemplate,如何获取用户列表并限制结果集?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个spring MVC应用程序,如何返回用户列表并限制结果?

I have a spring MVC application, how can I return a list of users and limit the results?

我的UserDao看起来像:

My UserDao looks like:

public List<User> getUsers(int limit) {
  return super.getHibernateTemplate()????
}


推荐答案

我假设你'为了分页而这样做。

I'm assuming you're doing this for purposes of paging.

你可以创建一个Query并使用setMaxResults和setFirstResult:

You can create a Query and use setMaxResults and setFirstResult:

public List<User> getUsers(int limit)
{
    Query q = getHibernateTemplate().getSession().createQuery("from User");
    q.setFirstResult(0); // modify this to adjust paging
    q.setMaxResults(limit);
    return (List<User>) q.list();
}

或者,使用HibernateCallback(这可能是最好的方法,尽管它更有语言):

Alternatively, use a HibernateCallback (this is probably the best method, although it's wordier):

    return getHibernateTemplate().executeFind(new HibernateCallback() {
        public Object doInHibernate(Session session) throws HibernateException, SQLException {
            Query q = session.createQuery("from User");
            q.setMaxResults(limit);
            return q.list();
        }
    });

另外还会为您处理异常翻译。

Which will additionally take care of exception translation for you.

这篇关于使用spring getHibernateTemplate,如何获取用户列表并限制结果集?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆