提供了JdbcTemplate 来封装数据库jdbc操作细节:
包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换
使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操作,简化传统的JDBC操作的复杂和繁琐过程。
1) 使用JdbcTemplate 更新(insert /update /delete)
1 |
int k = jdbcTemplate.update( "UPDATE tblname SET prop1=?,prop2=?..." , new Object[]{...}); |
1 |
jdbcTemplate.update( "INSERT INTO tblname VALUES(?,?,..)" , new Object[]{...}, |
2 |
new int []{Types.VARCHAR,Types.NUMERIC}); |
01 |
jdbcTemplate.update( "INSERT INTO tblname VALUES(?,?,..)" , |
02 |
new PreparedStatementSetter(){ |
03 |
public void setValues(PreparedStatement ps) throws SQLException{ |
04 |
ps.setLong( 1 , user.getId( 1 )); |
05 |
ps.setString( 2 , user.getName( 2 )); |
06 |
ps.setDate( 3 , new java.sql.Date( new Date().getTime()); |
07 |
ps.setTimestamp( 4 , new Timestamp( new Date().getTime()); |
2) 使用JdbcTemplate 查询 (select)
1 |
final User user = new User(); |
2 |
jdbcTemplate.query( "SELECT id,name,.. FROM tblname WHERE id=1" , |
3 |
new RowCallbackHandler(){ |
4 |
public void processRow(ResultSet rs) throws SQLException{ |
5 |
user.setId(rs.getLong( 1 )); |
6 |
user.setName(rs.getString( 2 )); |
01 |
List uGroup = jdbcTemplate.query( "SELECT id,name,.. FROM tblname WHERE igroup=1" , |
03 |
public Object mapRow(ResultSet rs, int no) throws SQLException{ |
04 |
User user = new User(); |
05 |
user.setId(rs.getLong( 1 )); |
06 |
user.setName(rs.getString( 2 )); |
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>?" , |
3 |
for (Map<String,Object> uMap :uMapList){ |
4 |
Integer id = uMap.get( "id" ); |
5 |
String name = uMap.get( "name" ); |
1 |
String user = jdbcTemplate.queryForObject( "SELECT name FROM tblname WHERE id=?" , |
2 |
new Integer []{ 5 }, String. class ); |
1 |
int uNum = jdbcTemplate.queryForInt( "SELECT count(*) FROM tblname WHERE id>?" , |
4)使用jdbc 操作类
a)扩展 MappingSqlQuery类
01 |
class JdbcQueryObject extends MappingSqlQuery { // extends SqlQuery |
02 |
public JdbcQueryObject (DataSource ds,String sql){ |
03 |
this .setDataSource( ds ); |
05 |
this .declareParameter( new Sqlparameter( "propName" , |
06 |
Types.VARCHAR); // propName 提示作用 |
09 |
public Object mapRow(ResultSet rs, int p) throws SQLException{ |
13 |
JdbcQueryObject queryObj = new JdbcQueryObject( ds, |
14 |
"SELECT .. FROM tblName WHERE param=?" ); |
15 |
List list = queryObj.execute( new Object[]{...}); |
b)使用 SqlFunction 类 查询单条结果
1 |
SqlFunction queryFun = new SqlFunction( ds, |
2 |
"select count(*) from tblName where ..." , new int []{Types.CHAR,...} ); |
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) ); |
4 |
updateFunc.update( new String[]{s1,s1}); |
5)支持jdbc 事务
spring的事务管理有两种方式:编程式事务、声明式事务
这里谈一下 基于数据库单一资源的编程式事务:
spring用实现TransactionDefinition接口的类定义事务的属性:传播行为;隔离级别;超时值;只读标志
默认实现为:DefaultTransactionDefinition类
01 |
PlatformTransactionManager tm = |
02 |
new DataSourceTransactionManager( |
03 |
jdbcTemplate.getDataSource() ); |
04 |
TransactionStatus status = null ; |
06 |
//null 默认事务属性配置DefaultTransactionDefinition |
07 |
status = tm.getTransaction( null ); |
08 |
for ( final String wd: words){ |
10 |
jdbcTemplate.update( insertWordSql, |
11 |
new PreparedStatementSetter(){ |
13 |
public void setValues(PreparedStatement pstate) |
15 |
pstate.setString( 1 , wd) ; |
16 |
pstate.setTimestamp( 2 , |
17 |
new Timestamp( new Date().getTime() )); |
22 |
} catch (DataAccessException e) { |
24 |
//tm.rollback(status); |
转自:http://hwqjavaeye.iteye.com/blog/289330
- (转)Spring JdbcTemplate 方法详解
Spring JdbcTemplate方法详解 文章来源:http://blog.csdn.net/dyllove98/article/details/7772463 JdbcTemplate主要提供 ...
- [转]Spring JdbcTemplate 查询分页
原文:http://blog.csdn.net/xiaofanku/article/details/4280128 现在进行的项目由于数据库的遗留原因(设计的不堪入目)不能用hibernate.所以用 ...
- spring jdbcTemplate query
1. spring jdbcTemplate query需要实现mapRow方法 package com.cdv.apolloagent.jdbc.dao.impl; import java.sql. ...
- Spring JdbcTemplate 的使用与学习(转)
紧接上一篇 (JdbcTemplate是线程安全的,因此可以配置一个简单的JdbcTemplate实例,将这个共享的实例注入到多个DAO类中.辅助的文档) Spring DAO支持 http://ww ...
- Spring JdbcTemplate的queryForList(String sql , Class<T> elementType)易错使用--转载
原文地址: http://blog.csdn.net/will_awoke/article/details/12617383 一直用ORM,今天用JdbcTemplate再次抑郁了一次. 首先看下这个 ...
- spring jdbcTemplate源码剖析
本文浅析 spring jdbcTemplate 源码,主要是学习其设计精髓.模板模式.巧妙的回调 一.jdbcTemplate 类结构 ①.JdbcOperations : 接口定义了方法,如 &l ...
- 使用Spring JDBCTemplate简化JDBC的操作
使用Spring JDBCTemplate简化JDBC的操作 接触过JAVA WEB开发的朋友肯定都知道Hibernate框架,虽然不否定它的强大之处,但个人对它一直无感,总感觉不够灵活,太过臃肿了. ...
- Apache Phoenix JDBC 驱动和Spring JDBCTemplate的集成
介绍:Phoenix查询引擎会将SQL查询转换为一个或多个HBase scan,并编排运行以生成标准的JDBC结果集. 直接使用HBase API.协同处理器与自己定义过滤器.对于简单查询来说,其性能 ...
- Spring JdbcTemplate用法整理
Spring JdbcTemplate用法整理: xml: <?xml version="1.0" encoding="UTF-8"?> <b ...
随机推荐
- wince和window mobile winphone
windows mobile是微软在2000年左右推出的针对移动平台的操作系统,这个系统一直使用到三年前,微软开始启用metro界面,将windows mobile改名为windows phone. ...
- jfinal框架教程-学习笔记(一)
JFinal 是基于 Java 语言的极速 WEB + ORM 开发框架,其核心设计目标是开发迅速.代码量少.学习简单.功能强大.轻量级.易扩展.Restful.在拥有Java 语言所有优势 ...
- poj 1364 King(差分约束)
题意(真坑):傻国王只会求和,以及比较大小.阴谋家们想推翻他,于是想坑他,上交了一串长度为n的序列a[1],a[2]...a[n],国王作出m条形如(a[si]+a[si+1]+...+a[si+ni ...
- 【CSS】css各种居中方法
水平居中的text-align:center 和 margin:0 auto 这两种方法都是用来水平居中的,前者是针对父元素进行设置而后者则是对子元素.他们起作用的首要条件是子元素必须没有被flo ...
- web项目Log4j日志输出路径配置问题
问题描述:一个web项目想在一个tomcat下运行多个实例(通过修改war包名称的实现),然后每个实例都将日志输出到tomcat的logs目录下实例名命名的文件夹下进行区分查看每个实例日志,要求通过尽 ...
- css3属性及事例
在看网上别的前端大牛的作品时,总会有新的收获,我想很多人应该都知道box-shadow,但是不知道有没有接触过这个 box-shadow: 2px 2px 4px rgba(0,0,0,0.4) , ...
- MySQL基础之第10章 查询数据
10.1.基本查询语句 SELECT 属性列表 FROM 表名和视图列表[WHERE条件表达式1][GROUPBY 属性名1 [HAVING条件表达式2]][ORDERBY 属性名2[ASC|DESC ...
- 关于join算法的四篇文章
MySQL Join算法与调优白皮书(一) MySQL Join算法与调优白皮书(二) MySQL Join算法与调优白皮书(三) MySQL Join算法与调优白皮书(四) MariaDB Join ...
- HDU 5832 A water problem
A water problem Time Limit: 5000/2500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- hdu 2818 Building Block(加权并查集)2009 Multi-University Training Contest 1
题意: 一共有30000个箱子,刚开始时都是分开放置的.接下来会有两种操作: 1. M x y,表示把x箱子所在的一摞放到y箱子那一摞上. 2. C y,表示询问y下方有多少个箱子. 输入: 首行输入 ...