maven开发ssh项目(struts2spring3hibernate3)【第三篇hibernate3之ssh整合开发具体操作(增删改查)之分页查询】

1、收先写个分页的bean用来保存查询到的数据

package utils;

import java.util.List;


public class PageBean<T> {
    private int page;    // 当前页数
    private int totalCount; // 总记录数
    private int totalPage; // 总页数
    private int limit;    // 每页显示的记录数
    private List<T> list; // 每页显示数据的集合.
    public int getPage() {
        return page;
    }
    public void setPage(int page) {
        this.page = page;
    }
    public int getTotalCount() {
        return totalCount;
    }
    public void setTotalCount(int totalCount) {
        this.totalCount = totalCount;
    }
    public int getTotalPage() {
        return totalPage;
    }
    public void setTotalPage(int totalPage) {
        this.totalPage = totalPage;
    }
    public int getLimit() {
        return limit;
    }
    public void setLimit(int limit) {
        this.limit = limit;
    }
    public List<T> getList() {
        return list;
    }
    public void setList(List<T> list) {
        this.list = list;
    }
    
}

2、因为this.getHibernateTemplate()提供的方法不足以让我们去完成分页(单表能行,我记得findByCriteria,findByExample可以进行分页查询)

这个是单表的不过我自己没试过

【DetachedCriteria来构造查询条件,参数需要查询的类
List l1=this.getHibernateTemplate().findByCriteria(DetachedCriteria.forClass(类CLASS), 开始记录 , 每页显示记录数);
应用实例查询
List l2=this.getHibernateTemplate().findByExample(new 类, 开始记录 , 每页显示记录数);

回归正题:既然提供的直接方法不足以那就用间接的:

<List<Object>> List<Object> org.springframework.orm.hibernate3.HibernateTemplate.execute(HibernateCallback<List<Object>> action) throws DataAccessException

这个是在dao层的写法

1、public List<Xsb> findAll(int first,int max){
        String hql="from po.Xsb";
        List<Xsb> list=this.getHibernateTemplate().execute(
                new PageHibernateCallback<>(hql, null, first, max)
                );
        return list;
    }

2、public List findAll(int first,int max){
        String hql="select a.xm,b.kcm,c.id.xh,c.cj,c.xf,c.id.kch from po.Xsb a"
                + ",po.Kcb b,po.Cjb c where a.xh=c.id.xh and b.kch=c.id.kch ";
        List list=this.getHibernateTemplate().execute(
                new PageHibernateCallback<>(hql, null, first, max)
                );
        return list;
    }

 

使用这个方法要写一个匿名内部类去实现HibernateCallback这个接口的方法或者直接写个工具类去实现接口)我是写工具类PageHibernateCallback啦【直接上代码】

package utils;

import java.sql.SQLException;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;

public class PageHibernateCallback<T> implements HibernateCallback<List<T>>{//这里使用T来指定某一类型
    
    private String hql;
    private Object[] params;//参数数组
    private int startIndex;
    private int pageSize;
    

    public PageHibernateCallback(String hql, Object[] params,
            int startIndex, int pageSize) {
        super();
        this.hql = hql;
        this.params = params;
        this.startIndex = startIndex;
        this.pageSize = pageSize;
    }

    public List<T> doInHibernate(Session session) throws HibernateException,
            SQLException {
        //1要 执行hql语句的实例
        Query query = session.createQuery(hql);
        //2 实际参数
        if(params != null){
            for(int i = 0 ; i < params.length ; i ++){
                query.setParameter(i, params[i]);
            }
        }
        //3 分页
        query.setFirstResult(startIndex);
        query.setMaxResults(pageSize);
        
        return query.list();
    }

}
然后是servers层的:

    2、public PageBean<Object> findAll(int page){
    int limit=5,totalPage=0;
    int first=(page-1)*limit;
    int totalCount=cjbDao.findNum().intValue();
    if(totalCount % limit == 0){
        totalPage = totalCount / limit;
    }else{
        totalPage = totalCount / limit + 1;
    }
    List list=cjbDao.findAll(first, limit);
    PageBean<Object> bean=new PageBean<>();
    bean.setTotalCount(totalCount);
    bean.setList(list);
    bean.setLimit(limit);
    bean.setPage(page);
    bean.setTotalPage(totalPage);
    
    return bean;
    
}

-----------------------------

1、public PageBean<Xsb> findAll(int page){
    int limit=5,totalPage=0;
    int first=(page-1)*limit;
    int totalCount=xsbDao.findNum().intValue();
    if(totalCount % limit == 0){
        totalPage = totalCount / limit;
    }else{
        totalPage = totalCount / limit + 1;
    }
    List<Xsb> list=xsbDao.findAll(first, limit);
    PageBean<Xsb> bean=new PageBean<>();
    bean.setTotalCount(totalCount);
    bean.setList(list);
    bean.setLimit(limit);
    bean.setPage(page);
    bean.setTotalPage(totalPage);
    
    return bean;
    
}

这样就完成了

题外话:想想我以前第一次写分页,我当时是把所有的数据都弄到前端然后用jq去隐藏显示(当时也是无知者无畏也^v^)

 

 

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值