写了个小项目,数据不多,现在是直接在action中用service调用return hibernateTemplate.find("from SNews order by news_id") ;然后JSP显示LIST结果。
数据多了这样很不方便,想用个分页。
我的思路是:查询结果时,默认显示第一页,默认比如显示10条数据,然后点 下一页 给后台传一个参数,然后查到第二页数据。
具体代码不会写了。。可否指点一二。
------解决方案--------------------
hibernate 的criteria和query都有setFirstResult和setFetchSize方法,很简单好用........
------解决方案--------------------
直接用hibernate自带的分页方法
public List<T> selectByPage(final String hql, final int pageNumber,
final int pageSize) {
return getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session s) throws HibernateException,
SQLException {
return (List<T>) s.createQuery(hql)
.setFirstResult((pageNumber - 1) * pageSize)
.setMaxResults(pageSize).list();
}
});
}
下一页什么的传对应的pageNumber,pageSize就可以了,如果你想很多页面要用的话,当然页面你还需要个分页标签。
------解决方案--------------------
如果是要显示全部信息的话,最好只查一次,然后可以在Action中分页,每次点下一页的时候就直接从List中取数据,不用在查数据库,只要你会算算术就行了。
如果是找数据,不确定是在哪一页的话可以直接用Hibernate提供的分页方法,简单。
------解决方案--------------------
挺想帮你的。刚用SSH做过分页。不过是老师给的文档。里面有具体步骤。不知道怎么跟你说哈。帮你顶个吧。
------解决方案--------------------
Criteria ct = getSession().createCriteria(TbBook.class);
ct.addOrder(Order.asc("bookId"));
ct.setFirstResult(start);
ct.setMaxResults(end);
return ct.list();
分页的例子
------解决方案--------------------
前几天做的分页显示,测试没问题,楼主参考下吧
- Java code
public class Serch extends ActionSupport{ private String bid; private String bname; private int number; private int k;//储存最大页面数 private int pageNow=1; //页码数,初始为1 private int pageSize = 5 ; //页面行数 private int intRowCount;//总行数 private int intPageCount;//总页数 private int lastPage; private int p=1;.....set/get;public String execute() throws Exception { List list=new List(); java.util.List L=new ArrayList(); L=list.list(); intRowCount=L.size(); System.out.println("链表的长度:"+L.size()); if(L.size()%pageSize==0) //判断分多少页 this.lastPage=L.size()/pageSize; else this.lastPage=L.size()/pageSize+1; this.setIntPageCount(this.lastPage);//存入总页数 if(this.pageNow<1)//如果当前页码是第一页在点第一页的时候也跳转到第一页 this.pageNow=1; if(this.pageNow>this.lastPage)//同理只不过是最后一页 this.pageNow=this.lastPage; /* * * 假设取其中20-25条 * * * */ int startIndex=(this.pageNow-1)*pageSize;//截止条目开始,第20条 int endIndex=startIndex+pageSize;//截止条目结束 第25条 if(endIndex>=L.size()) endIndex=L.size(); L= L.subList(startIndex, endIndex); System.out.println("执行"); ActionContext.getContext().put("list", L); return "success";}@Overridepublic void validate() { // TODO Auto-generated method stub super.validate();}}前台显示:共<s:property value="intRowCount"/>记录 共<s:property value="intPageCount"/>页 第<s:property value="pageNow"/>页 <s:url action="Serch.action" id="url"> <s:param name="pageNow"> <s:property value="1" /> </s:param> </s:url> <s:a href="%{url}">首页</s:a> <s:url action="Serch.action" id="url"> <s:param name="pageNow"> <s:property value="%{pageNow-1}" /> </s:param> </s:url> <s:a href="%{url}">上一页</s:a> <s:url action="Serch.action" id="url"> <s:param name="pageNow"> <s:property value="%{pageNow+1}" /> </s:param> </s:url> <s:a href="%{url}">下一页</s:a> <s:url action="Serch.action" id="url"> <s:param name="pageNow"> <s:property value="lastPage" /> </s:param> </s:url> <s:a href="%{url}">尾页</s:a>