Fork me on GitHub

Spring之JdbcTemplate

JdbcTemplate

  • execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;
  • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
  • query方法及queryForXXX方法:用于执行查询相关语句;
  • call方法:用于执行存储过程、函数相关语句。
//update操作单个增删改
int update(String sql,Object[] args)
int update(String sql,Objcet... args)

//batchUpdate批量增删改
int[] batchUpdate(String[] sql)
int[] batchUpdate(String sql,List<Object[]>)

//获取单条数据(单列)
T queryForObject(String sql,Class<T> type)
T queryForObject(String sql,Object[] args,Class<T> type)
T queryForObject(String sql,Class<T> type,Object... arg)

//获取多条数据(单列)
List<T> queryForList(String sql,Class<T> type)
List<T> queryForList(String sql,Object[] args,Class<T> type)
List<T> queryForList(String sql,Class<T> type,Object... arg)

/*查询复杂对象(封装为Map)*///获取单个,如果没有查到记录会throw DataAccess异常而不是返回null,所以如果存在查不到记录的情况下,尽量用queryForList代替。
Map queryForMap(String sql)
Map queryForMap(String sql,Objcet[] args)
Map queryForMap(String sql,Object... arg)

//获取多个
List<Map<String,Object>> queryForList(String sql)
List<Map<String,Object>> queryForList(String sql,Obgject[] args)
List<Map<String,Object>> queryForList(String sql,Obgject... arg)

/*查询复杂对象(封装为实体对象):
Spring JdbcTemplate是通过实现org.springframework.jdbc.core.RowMapper这个接口来完成对entity对象映射。*/

//获取单个对象
T queryForObject(String sql,RowMapper<T> mapper)
T queryForObject(String sql,object[] args,RowMapper<T> mapper)
T queryForObject(String sql,RowMapper<T> mapper,Object... arg)

//获取多个对象
List<T> query(String sql,RowMapper<T> mapper)
List<T> query(String sql,Object[] args,RowMapper<T> mapper)
List<T> query(String sql,RowMapper<T> mapper,Object... arg)

Spring提供的JDBC模板

  • JdbcTemplate:Spring里最基本的JDBC模板,利用JDBC和简单的索引参数查询提供对数据库的简单访问。
  • NamedParameterJdbcTemplate:能够在执行查询时把值绑定到SQL里的命名参数,而不是使用索引参数。
  • SimpleJdbcTemplate:利用Java 5的特性,比如自动装箱、通用(generic)和可变参数列表来简化JDBC模板的使用。

NamedParameterJdbcTemplate

SqlParameterSource

可以使用SqlParameterSource实现作为来实现为命名参数设值,默认实现有 :

1. MapSqlParameterSource:  实现非常简单,只是封装了java.util.Map;

2. BeanPropertySqlParameterSource: 封装了一个JavaBean对象,通过JavaBean对象属性来决定命名参数的值。

3. EmptySqlParameterSource: 一个空的SqlParameterSource ,常用来占位使用

RowMapper

这个接口为了实现sql查询结果和对象间的转换,可以自己实现,也可以使用系统实现,主要实现类有:

1. SingleColumnRowMapper: sql结果为一个单列的数据,如List<String> , List<Integer>,String,Integer等

2. BeanPropertyRowMapper: sql结果匹配到对象 List< XxxVO>,XxxVO

增删改

API: int update(String sql, Map<String, ?> paramMap)

插入/修改/删除数据,使用update方法

使用Map作为参数

单行单列数据

API: public < T > T queryForObject(String sql, Map<String, ?> paramMap, Class<T> requiredType)

API: public < T > T queryForObject(String sql, SqlParameterSource paramSource, Class<T> requiredType)

多行单列数据

API: public < T> List< T> queryForList(String sql, Map<String, ?> paramMap, Class< T > elementType)

API: public < T> List< T> queryForList(String sql, SqlParameterSource paramSource, Class< T> elementType)

单行数据

API: public < T> T queryForObject(String sql, Map< String, ?> paramMap, RowMapper< T>rowMapper)

API: public < T> T queryForObject(String sql, SqlParameterSource paramSource, RowMapper< T> rowMapper)

Map形式的单行数据

API: public Map< String, Object> queryForMap(String sql, Map< String, ?> paramMap)

API: public Map< String, Object> queryForMap(String sql, SqlParameterSource paramSource)

多行数据

API: public < T> List< T> query(String sql, Map< String, ?> paramMap, RowMapper< T> rowMapper)

API: public < T> List< T> query(String sql, SqlParameterSource paramSource, RowMapper< T> rowMapper)

API: public < T> List< T> query(String sql, RowMapper< T> rowMapper)

Map形式的多行数据

API: public List< Map< String, Object>> queryForList(String sql, Map< String, ?> paramMap)

API: public List< Map< String, Object>> queryForList(String sql, SqlParameterSource paramSource)

 

JdbcTemplate实现分页 

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

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

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

参考:

https://www.cnblogs.com/myitnews/p/12347541.html#autoid-0-0-0

插入/修改/删除数据,使用updateXXX方法

使用Map作为参数

API: int update(String sql, Map<String, ?> paramMap)

posted @ 2018-06-26 14:23  秋夜雨巷  阅读(29203)  评论(0编辑  收藏  举报