Spring的JdbcTemplate實現分頁

 PageList.java實體類java

/**
 * 封裝分頁對象 
 **/
public class PageList {
    private int page;   //當前頁
    private int totalRows;   //總行數
    private int pages;    //總頁數
    private List list=new ArrayList();

    public int getPage() {
        return page;
    }

    public void setPage(int page) {
        this.page = page;
    }

    public int getPages() {
        return pages;
    }

    public void setPages(int pages) {
        this.pages = pages;
    }

    public List getList() {
        if(list==null){
            list=new ArrayList();
        }
        return list;
    }

    public void setList(List list) {
        this.list = list;
    }

    public int getTotalRows() {
        return totalRows;
    }

    public void setTotalRows(int totalRows) {
        this.totalRows = totalRows;
    }
}

dao層sql

   /**
     * 只查詢一列數據類型對象。用於只有一行查詢結果的數據
     * @param sql
     * @param params
     * @param cla Integer.class,Float.class,Double.Class,Long.class,Boolean.class,Char.class,Byte.class,Short.class
     * @return
     */
    public Object queryOneColumnForSigetonRow(String sql,Object[] params,Class cla){
        Object result=null;
        try{
            if(params==null||params.length>0){
                result=jdbcTemplate.queryForObject(sql,params,cla);
            }else{
                result=jdbcTemplate.queryForObject(sql,cla);
            }
        }catch(Exception ex){
            ex.printStackTrace();
        }
        return result;
    }
/** * 查詢返回實體對象集合 * @param sql sql語句 * @param params 填充sql問號佔位符數 * @param cla 實體對象類型 * @return */ public List queryForObjectList(String sql,Object[] params,final Class cla){ final List list=new ArrayList(); try{ jdbcTemplate.query(sql, params, new RowCallbackHandler(){ public void processRow(ResultSet rs) { try{ List<String> columnNames=new ArrayList<String>(); ResultSetMetaData meta=rs.getMetaData(); int num=meta.getColumnCount(); for(int i=0;i<num;i++){ columnNames.add(meta.getColumnLabel(i+1).toLowerCase().trim()); } Method[] methods=cla.getMethods(); List<String> fields=new ArrayList<String>(); for(int i=0;i<methods.length;i++){ if(methods[i].getName().trim().startsWith("set")){ String f=methods[i].getName().trim().substring(3); f=(f.charAt(0)+"").toLowerCase().trim()+f.substring(1); fields.add(f); } } do{ Object obj=null; try{ obj=cla.getConstructor().newInstance(); }catch(Exception ex){ ex.printStackTrace(); } for(int i=0;i<num;i++){ Object objval=rs.getObject(i+1); for(int n=0;n<fields.size();n++){ String fieldName=fields.get(n).trim(); if(columnNames.get(i).equals(fieldName.toLowerCase().trim())){ BeanUtils.copyProperty(obj, fieldName, objval); break; } } } list.add(obj); }while(rs.next()); }catch(Exception ex){ ex.printStackTrace(); } } }); }catch(Exception ex){ex.printStackTrace();} if(list.size()<=0){ return null; } return list; }
/** * 查詢返回List<Map<String,Object>>格式數據,每個Map表明一行數據,列名爲key * @param sql sql語句 * @param params 填充問號佔位符數 * @return */ public List<Map<String,Object>> queryForMaps(String sql,Object[] params){ try{ if(params!=null&&params.length>0){ return jdbcTemplate.queryForList(sql, params); } return jdbcTemplate.queryForList(sql); }catch(Exception ex){ ex.printStackTrace(); } return null; } /** * 查詢分頁(MySQL數據庫) * @param sql 終執行查詢的語句 * @param params 填充sql語句中的問號佔位符數 * @param page 想要第幾頁的數據 * @param pagerow 每頁顯示多少條數 * @param cla 要封裝成的實體元類型 * @return pageList對象 */ public PageList queryByPageForMySQL(String sql, Object[] params, int page, int pagerow,Class cla) { String rowsql="select count(*) from ("+sql+") gmtxtabs_"; //查詢總行數sql int pages = 0; //總頁數 int rows=(Integer)queryOneColumnForSigetonRow(rowsql, params, Integer.class); //查詢總行數 //判斷頁數,若是是頁大小的整數倍就爲rows/pageRow若是不是整數倍就爲rows/pageRow+1 if (rows % pagerow == 0) { pages = rows / pagerow; } else { pages = rows / pagerow + 1; } //查詢第page頁的數據sql語句 if(page<=1){ sql+=" limit 0,"+pagerow; }else{ sql+=" limit "+((page-1)*pagerow)+","+pagerow; } //查詢第page頁數據 List list=null; if(cla!=null){ list=queryForObjectList(sql, params, cla); }else{ list=queryForMaps(sql, params); } //返回分頁格式數據 PageList pl =new PageList(); pl.setPage(page); //設置顯示的當前頁數 pl.setPages(pages); //設置總頁數 pl.setList(list); //設置當前頁數據 pl.setTotalRows(rows); //設置總記錄數 return pl; }

service層數據庫

controller層this

        if(null==pageNo)
        {
            pageNo = 1;
        }

        if(null==pageSize)
        {
            pageSize = 30;
        }
        PageList list = service.getAllNotice(unitid, pageNo, pageSize);
相關文章
相關標籤/搜索