博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Spring的JdbcTemplate实现分页
阅读量:5860 次
发布时间:2019-06-19

本文共 3823 字,大约阅读时间需要 12 分钟。

 PageList.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层

/**     * 只查询一列数据类型对象。用于只有一行查询结果的数据     * @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
columnNames=new ArrayList
(); ResultSetMetaData meta=rs.getMetaData(); int num=meta.getColumnCount(); for(int i=0;i
fields=new ArrayList
(); for(int i=0;i
>格式数据,每一个Map代表一行数据,列名为key * @param sql sql语句 * @param params 填充问号占位符数 * @return */ public List
> 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层

if(null==pageNo)        {            pageNo = 1;        }        if(null==pageSize)        {            pageSize = 30;        }        PageList list = service.getAllNotice(unitid, pageNo, pageSize);

 

转载于:https://www.cnblogs.com/aeolian/p/9228907.html

你可能感兴趣的文章
Oculus创始人面临窃取商业机密指控
查看>>
传Snapchat已递交IPO申请 拟至多融资40亿美元
查看>>
美国OTA更新《物联网信任框架》:未来物联网认证计划的基础
查看>>
制造业原材料价格上涨 安防设备涨还是不涨?
查看>>
硬盘都白菜价了,可我们连卖“白菜”都不够格
查看>>
ARM发力物联网
查看>>
我怎么做性能测试
查看>>
“十三五”规划强调信息安全
查看>>
欧盟斥资18亿欧元 砸向网络安全领域——英国,你后悔了没?
查看>>
网络安全专家寻勒索病毒蛛丝马迹 警告更多风险
查看>>
百亿交易额被指造假!科通芯城创始人报警回应
查看>>
AOFAX呼叫中心:企业如何提升竞争力和凝聚力
查看>>
以大数据探寻社会治理精准模式
查看>>
阿里巴巴集团技术委员会主席王坚:我曾经被诺贝尔奖得主司马贺忽悠,相信人工智能就是未来!...
查看>>
北控清洁能源俩附属订立光伏发电设备融资租赁协议
查看>>
慈溪:创卫,让城市生活更美好
查看>>
大数据经济价值报告发布 零售业最受益
查看>>
基于光纤网络视频监控系统
查看>>
Qt之显示网络图片
查看>>
《CCNA路由和交换(200-120)学习指南》——1.2节网络拓扑
查看>>