使用spring getHibernateTemplate,如何获取用户列表并限制结果集? [英] With springs getHibernateTemplate, how can I get a list of users and limit the result set?
本文介绍了使用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屋!
查看全文