提供了JdbcTemplate 来封装数据库jdbc操作细节: 
包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换

使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操作,简化传统的JDBC操作的复杂和繁琐过程。

1) 使用JdbcTemplate 更新(insert /update /delete)

1 int k = jdbcTemplate.update("UPDATE tblname SET prop1=?,prop2=?..."newObject[]{...});
1 jdbcTemplate.update("INSERT INTO tblname VALUES(?,?,..)"new Object[]{...},
2      new int[]{Types.VARCHAR,Types.NUMERIC});
01 jdbcTemplate.update("INSERT INTO tblname VALUES(?,?,..)",                    
02         newPreparedStatementSetter(){                         
03                public void setValues(PreparedStatement ps) throwsSQLException{     
04                     ps.setLong(1, user.getId(1));
05                     ps.setString(2, user.getName(2));  
06                     ps.setDate(3new java.sql.Date(newDate().getTime()); 
07                     ps.setTimestamp(4new Timestamp(new Date().getTime());
08                }                    
09         }
10 );

2) 使用JdbcTemplate 查询 (select)

1 final User user = newUser();
2 jdbcTemplate.query("SELECT id,name,.. FROM tblname WHERE id=1",
3        newRowCallbackHandler(){
4               public void processRow(ResultSet rs) throwsSQLException{
5                     user.setId(rs.getLong(1));
6                     user.setName(rs.getString(2));
7               }
8       }
9 );
01 List uGroup = jdbcTemplate.query("SELECT id,name,.. FROM tblname WHERE igroup=1",
02      newRowMapper(){
03             public Object mapRow(ResultSet rs,int no) throwsSQLException{
04                      User user = newUser();
05                      user.setId(rs.getLong(1));
06                      user.setName(rs.getString(2));
07                      returnuser ;
08             }
09      }
10 };

3)使用JdbcTemplate 便捷方法

1 List uNames = jdbcTemplate.queryForList("SELECT name FROM tblname WHERE id>?",
2     new Integer []{5}, String.class);
1 List<Map> uMapList = (List<Map>) jdbcTemplate.queryForList( "SELECT id, name FROM tblname WHERE id>?",
2              newInteger []{5});
3 for(Map<String,Object> uMap :uMapList){
4       Integer id = uMap.get("id");
5       String name = uMap.get("name");
6 };
1 String user = jdbcTemplate.queryForObject("SELECT name FROM tblname WHERE id=?",
2      new Integer []{5}, String.class );
1 intuNum = jdbcTemplate.queryForInt("SELECT count(*) FROM tblname WHERE id>?",
2     new Integer []{5});

4)使用jdbc 操作类

a)扩展 MappingSqlQuery类

01 class JdbcQueryObject extends MappingSqlQuery { // extends SqlQuery
02       public JdbcQueryObject (DataSource ds,String sql){
03             this.setDataSource( ds );
04             this.setSql( sql );
05             this.declareParameter(newSqlparameter("propName",
06                 Types.VARCHAR);// propName 提示作用
07         this.compile();
08       }
09       public Object mapRow(ResultSet rs,int p) throws SQLException{
10                  // ...
11      }
12 }
13 JdbcQueryObject queryObj = new JdbcQueryObject( ds,
14       "SELECT .. FROM tblName WHERE param=?");
15 List list = queryObj.execute(new Object[]{...});

b)使用 SqlFunction 类 查询单条结果

1 SqlFunction queryFun = newSqlFunction( ds,
2       "select count(*) from tblName where ..." ,new int[]{Types.CHAR,...} );
3 queryFun.compile();
4 queryFun.run(new Object[]{p1,p2,..});

c)使用 SqlUpdate 类 更新

1 SqlUpdate updateFunc = new SqlUpdate(ds ,"INSERT tblName ...");
2 updateFunc.declareParameter( new SqlParameter("prop",Types.CHAR) );
3 updateFunc.compile();
4 updateFunc.update(new String[]{s1,s1});

5)支持jdbc 事务

spring的事务管理有两种方式:编程式事务、声明式事务

这里谈一下 基于数据库单一资源的编程式事务:

spring用实现TransactionDefinition接口的类定义事务的属性:传播行为;隔离级别;超时值;只读标志

默认实现为:DefaultTransactionDefinition类

01 PlatformTransactionManager tm = 
02 newDataSourceTransactionManager(
03             jdbcTemplate.getDataSource() );
04 TransactionStatus status = null;
05 try{
06     //null 默认事务属性配置DefaultTransactionDefinition
07     status = tm.getTransaction(null);          
08   for(finalString wd: words){         
09    try {
10      jdbcTemplate.update( insertWordSql,
11           new PreparedStatementSetter(){
12  
13     public voidsetValues(PreparedStatement pstate)
14                      throws SQLException {
15                 pstate.setString(1, wd) ;
16         pstate.setTimestamp(2,
17         new Timestamp( newDate().getTime() ));                            
18     }                  
19         }
20      );                
21              
22    catch (DataAccessException e) {
23        e.printStackTrace();
24        //tm.rollback(status);
25     }
26     // end for
27 finally {
28      tm.commit(status);
29 }  

转自:http://hwqjavaeye.iteye.com/blog/289330

Spring JdbcTemplate小结的更多相关文章

  1. (转)Spring JdbcTemplate 方法详解

    Spring JdbcTemplate方法详解 文章来源:http://blog.csdn.net/dyllove98/article/details/7772463 JdbcTemplate主要提供 ...

  2. [转]Spring JdbcTemplate 查询分页

    原文:http://blog.csdn.net/xiaofanku/article/details/4280128 现在进行的项目由于数据库的遗留原因(设计的不堪入目)不能用hibernate.所以用 ...

  3. spring jdbcTemplate query

    1. spring jdbcTemplate query需要实现mapRow方法 package com.cdv.apolloagent.jdbc.dao.impl; import java.sql. ...

  4. Spring JdbcTemplate 的使用与学习(转)

    紧接上一篇 (JdbcTemplate是线程安全的,因此可以配置一个简单的JdbcTemplate实例,将这个共享的实例注入到多个DAO类中.辅助的文档) Spring DAO支持 http://ww ...

  5. Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)易错使用--转载

    原文地址: http://blog.csdn.net/will_awoke/article/details/12617383 一直用ORM,今天用JdbcTemplate再次抑郁了一次. 首先看下这个 ...

  6. spring jdbcTemplate源码剖析

    本文浅析 spring jdbcTemplate 源码,主要是学习其设计精髓.模板模式.巧妙的回调 一.jdbcTemplate 类结构 ①.JdbcOperations : 接口定义了方法,如 &l ...

  7. 使用Spring JDBCTemplate简化JDBC的操作

    使用Spring JDBCTemplate简化JDBC的操作 接触过JAVA WEB开发的朋友肯定都知道Hibernate框架,虽然不否定它的强大之处,但个人对它一直无感,总感觉不够灵活,太过臃肿了. ...

  8. Apache Phoenix JDBC 驱动和Spring JDBCTemplate的集成

    介绍:Phoenix查询引擎会将SQL查询转换为一个或多个HBase scan,并编排运行以生成标准的JDBC结果集. 直接使用HBase API.协同处理器与自己定义过滤器.对于简单查询来说,其性能 ...

  9. Spring JdbcTemplate用法整理

    Spring JdbcTemplate用法整理: xml: <?xml version="1.0" encoding="UTF-8"?> <b ...

随机推荐

  1. 学习:java设计模式—工厂模式

    一.工厂模式主要是为创建对象提供过渡接口,以便将创建对象的具体过程屏蔽隔离起来,达到提高灵活性的目的. 工厂模式在<Java与模式>中分为三类: 1)简单工厂模式(Simple Facto ...

  2. Java [Leetcode 169]Majority Element

    题目描述: Given an array of size n, find the majority element. The majority element is the element that ...

  3. svn强制提交备注信息

    当我们用tortoisesvn,提交代码时,有很多人不喜欢写注释的,代码版本多了,根本搞不清,哪个版本改了什么东西?所以如果加一些注释的话,我们看起来,也方便很多.所以在提交的时候,我会强制要求,写注 ...

  4. JOB的创建,定时,执行

    --建表 create table test_job(para_date date);  commit;  insert into test_job values(sysdate);  commit; ...

  5. 强制将IE8设置为IE7兼容模式来解析网页

    强制将IE8设置为IE7兼容模式来解析网页 英文原文:http://msdn.microsoft.com/en-us/library/cc288325(VS.85).aspx 文件兼容性用于定义让IE ...

  6. ASP.NET MVC+Bootstrap个人博客之修复UEditor编辑时Bug(四)

    我的个人博客站在使用百度富文本编辑器UEditor修改文章时,遇到了一些问题,(不知是bug,还是我没有配置好).但总算找到了解决方法,在此记录下来. 小站首页文章列表显示为(显示去除HTML标签后的 ...

  7. AE与AO的区别

    在ArcGis9.0之前,ArcObject还不是一个独立的产品,一直捆绑在Desktop产品中,只要你购买了desktop产品中的一个,你就可 以使用arcboject开发.从ArcGis9.0开始 ...

  8. [Everyday Mathematics]20150204

    设 $k_0>0$, $\phi:[k_0,\infty)\to[0,\infty)$ 是有界递减函数, 并且 $$\bex \phi(k)\leq \frac{A}{(k-h)^\al}\ph ...

  9. Java中的10颗语法糖

    语法糖(Syntactic Sugar):也称糖衣语法,指在计算机语言中添加的某种语法,这种语法对语言的功能没有影响,但是更方便程序员使用.通常来说,使用语法糖能够增加程序的可读性,减少程序代码出错的 ...

  10. android 滑动菜单SlidingMenu的实现

    首先我们看下面视图:       这种效果大家都不陌生,网上好多都说是仿人人网的,估计人家牛逼出来的早吧,我也参考了一一些例子,实现起来有三种方法,我下面简单介绍下: 方法一:其实就是对Gesture ...