【记录】SSH分页查询功能

分页查询 效果图:
效果图
第一步:写dao(注意:这里直接写实现类)

    @Override
    public int findCount() {
        String hql="select count(*) from SysDictionaries";
        List<Long> list = this.getHibernateTemplate().find(hql);
        if (list.size()>0){
            return list.get(0).intValue();
        }
        return 0;
    }

    @Override
//    分页查询字典
    public List<SysDictionaries> findByPage(int begin, int pageSize) {
        DetachedCriteria criteria = DetachedCriteria.forClass(SysDictionaries.class);
        List<SysDictionaries> list = this.getHibernateTemplate().findByCriteria(criteria,begin,pageSize);
        return list;
    }

第二步:Service类

//    分页查询
    public PageBean<SysDictionaries> findByPage(Integer currPage) {
        PageBean<SysDictionaries> pageBean = new PageBean<SysDictionaries>();
//        封装当前页数
        pageBean.setCurrPage(currPage);
//        每页显示记录数
        int pageSize =  10;
        pageBean.setPageSize(pageSize);
//        数据库总记录数
        int totalCount = dictDao.findCount();
        pageBean.setTotalCount(totalCount);
//        总页数
        double tc = totalCount;
        Double num = Math.ceil(tc/pageSize);
        pageBean.setCurrPage(num.intValue());
//        每页显示的数据
        int begin=(currPage-1)*pageSize;
        List<SysDictionaries> list = dictDao.findByPage(begin,pageSize);
        pageBean.setList(list);
        return pageBean;
    }

第三步:Action类

//    当前页面为1
    private Integer currPage = 1;
    public void setCurrPage(Integer currPage) {
        this.currPage = currPage;
    }

    //    分页查询
    public String findAll(){
        PageBean<SysDictionaries> pageBean = dictService.findByPage(currPage);
//        把pageBean存入值栈
        ActionContext.getContext().getValueStack().push(pageBean);
        return "findAll";
    }

struts配置文件,自己写就可以了

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值