【記錄】SSH分頁查詢功能

桂春GuiChun發表於2020-01-19

分頁查詢 效果圖:
效果圖
第一步:寫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配置檔案,自己寫就可以了

相關文章