`

使用Spring的NamedParameterJdbcTemplate完成DAO操作

阅读更多

NamedParameterJdbcTemplate内部包含了一个JdbcTemplate,所以JdbcTemplate能做的事情NamedParameterJdbcTemplate都能干,NamedParameterJdbcTemplate相对于JdbcTemplate主要增加了参数可以命名的功能。

public Object queryForObject(String sql, Map paramMap, RowMapper rowMapper)

public Object queryForObject(String sql, SqlParameterSource paramSource, RowMapper rowMapper)

       SqlParameterSource的两个主要实现MapSqlParameterSource

       BeanPropertySqlParameterSource

public int update(String sql, SqlParameterSource paramSource, KeyHolder generatedKeyHolder)保存数据获得主键。 

实例说明:

/**

 * 一、NamedParameterJdbcTemplate提供了命名参数,用:x代替了?

 * NamedParameterJdbcTemplate传参数可以用map或者SqlParameterSource

 * map的好处是:x,x的值可以自由取,但是所有参数的值都必须要放到map中去,其中的key:后面的名称,value是你传的值

 * SqlParameterSource的好处是不用一个个的赋值,但是:x中的x的值必须和对象的属性名称一样

 

 * 二、使用KeyHolder keyholder=new GeneratedKeyHolder();

   namedjdbctemp.update(sql, ps,keyholder);这个参数可以获得主键生成值

 */

public class StuDaoImple implements StuDaointer{ 

    private NamedParameterJdbcTemplate namedjdbctemp;

 

    public StuDaoImple(){

       namedjdbctemp=new NamedParameterJdbcTemplate(SQLConnUtil.getDataSource());

    }// SQLConnUtilJDBC工具类,提供了得到数据源的静态方法

    /*

     * 这里会用到NamedParameterJdbcTemplate两个好处:

     * 1,不用一个个的为参数赋值。

     * 2,可以轻易的得到主键自动增长值

     */

    public void addStu(Stu stu) {

       String sql="insert into stu values(:sname,:ssex,:sbrith)";

       //:后面的名称必须和stu属性名称一样

       SqlParameterSource ps=new BeanPropertySqlParameterSource(stu);

       KeyHolder keyholder=new GeneratedKeyHolder();

       namedjdbctemp.update(sql, ps,keyholder);

       //加上KeyHolder这个参数可以得到添加后主键的值

       int m=keyholder.getKey().intValue();

       System.out.println(m);

       //Map map=keyholder.getKeys();//这样可以得到联合主键的值

       //keyholder.getKeyList();//这样可以得到一些主主键值,若一次添加好几条记录

    }

    public int count() {

       String sql="select count(*) from stu";

       //可以通过NamedParameterJdbcTemplate得到JdbcTemplate

       int m=namedjdbctemp.getJdbcOperations().queryForInt(sql);

       return m;

    }

 

    /*

     * 这里会用到NamedParameterJdbcTemplate另一个好处:

     * 位置参数

     */

    public void delStu(int sid) {

       String sql="delete stu where s_id=:id";

       Map map=new HashMap();

       map.put("id", sid);

       namedjdbctemp.update(sql, map);

    }

    public List getAllStu() {

       String sql="select s_id as sid,s_name as sname,s_sex as ssex,s_brith as sbrith from stu";

       List list=namedjdbctemp.getJdbcOperations().query(sql,new BeanPropertyRowMapper(Stu.class));

       return list;

    }

    public List getAllStu(Stu stu) {

       String sql="select s_id as sid,s_name as sname,s_sex as ssex,s_brith as sbrith from stu where s_id=:sid";

       SqlParameterSource ps=new BeanPropertySqlParameterSource(stu);

       return namedjdbctemp.query(sql, ps, new BeanPropertyRowMapper(Stu.class));

    }

    public Stu getOneStu(Stu stu) {

       String sql="select s_id as sid,s_name as sname,s_sex as ssex,s_brith as sbrith from stu where s_id=:sid";

       SqlParameterSource ps=new BeanPropertySqlParameterSource(stu);

       return (Stu)namedjdbctemp.queryForObject(sql, ps, new BeanPropertyRowMapper(Stu.class));

    }

    public String getStuName(Stu stu) {

       String sql="select s_name as sname from stu where s_name=:sname";

       SqlParameterSource ps=new BeanPropertySqlParameterSource(stu);

       return (String)namedjdbctemp.queryForObject(sql, ps, String.class);

    }

    public void updStu(Stu stu) {

       String sql="update stu set s_name=:sname,s_sex=:ssex,s_brith=:sbrith where s_id=:sid";

       SqlParameterSource ps=new BeanPropertySqlParameterSource(stu);

       namedjdbctemp.update(sql, ps);

    }

}

7
0
分享到:
评论
4 楼 851228082 2015-06-04  
queryForObject结果集是空时,会出现EmptyDataAccessException,楼主,怎么处理的?
3 楼 democreen 2012-07-27  
  nice!
2 楼 jiguansheng 2012-07-10  
1 楼 水墨香兰 2011-12-09  

相关推荐

    Spring.3.x企业应用开发实战(完整版).part2

    经过历时一年的重大调整改版而成的,本书延续了上一版本追求深度,注重原理,不停留在技术表面的写作风格,力求使读者在熟练使用Spring的各项功能的同时,还能透彻理解Spring的内部实现,真正做到知其然知其所以然。...

    Spring 2.0 开发参考手册

    12.2.4. 不使用回调的基于Spring的DAO实现 12.2.5. 基于Hibernate3的原生API实现DAO 12.2.6. 编程式的事务划分 12.2.7. 声明式的事务划分 12.2.8. 事务管理策略 12.2.9. 容器资源 vs 本地资源 12.2.10. 在应用...

    Spring-Reference_zh_CN(Spring中文参考手册)

    12.2.4. 不使用回调的基于Spring的DAO实现 12.2.5. 基于Hibernate3的原生API实现DAO 12.2.6. 编程式的事务划分 12.2.7. 声明式的事务划分 12.2.8. 事务管理策略 12.2.9. 容器资源 vs 本地资源 12.2.10. 在应用服务器...

    Spring中文帮助文档

    12.2.4. 不使用回调的基于Spring的DAO实现 12.2.5. 基于Hibernate3的原生API实现DAO 12.2.6. 编程式的事务划分 12.2.7. 声明式的事务划分 12.2.8. 事务管理策略 12.2.9. 容器资源 vs 本地资源 12.2.10. 在应用...

    Spring API

    12.2.4. 不使用回调的基于Spring的DAO实现 12.2.5. 基于Hibernate3的原生API实现DAO 12.2.6. 编程式的事务划分 12.2.7. 声明式的事务划分 12.2.8. 事务管理策略 12.2.9. 容器资源 vs 本地资源 12.2.10. 在应用...

    spring chm文档

    12.2.4. 不使用回调的基于Spring的DAO实现 12.2.5. 基于Hibernate3的原生API实现DAO 12.2.6. 编程式的事务划分 12.2.7. 声明式的事务划分 12.2.8. 事务管理策略 12.2.9. 容器资源 vs 本地资源 12.2.10. 在应用...

    Spring3.x企业应用开发实战(完整版) part1

    经过历时一年的重大调整改版而成的,本书延续了上一版本追求深度,注重原理,不停留在技术表面的写作风格,力求使读者在熟练使用Spring的各项功能的同时,还能透彻理解Spring的内部实现,真正做到知其然知其所以然。...

    spring-framework-reference-4.1.2

    3. New Features and Enhancements in Spring Framework 4.0 ............................................ 17 3.1. Improved Getting Started Experience .........................................................

    appframework:从 code.google.compappframework 自动导出

    提供对 spring NamedParameterJdbcTemplate、Hibernate、Mybatis 的支持 在 ParameterMapper(包括 map 和 java bean)中提供包装的 http 请求参数(自 2.0.0 起) 为http请求提供service/dao的异步调用 提供页面/...

    spring-framework-reference4.1.4

    3. New Features and Enhancements in Spring Framework 4.0 ............................................ 17 3.1. Improved Getting Started Experience .........................................................

    springmvc-jdbcTemplate

    import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate; import com.flong.commons.lang.exception.DaoAccessException; import com.flong.commons.persistence.Entity; import ...

Global site tag (gtag.js) - Google Analytics