提供了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(3, new java.sql.Date(newDate().getTime()); |
07 |
ps.setTimestamp(4, new Timestamp(new Date().getTime()); |
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)); |
01 |
List uGroup = jdbcTemplate.query("SELECT id,name,.. FROM tblname WHERE igroup=1", |
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)); |
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 |
intuNum = 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(newSqlparameter("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 = newSqlFunction( 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 |
newDataSourceTransactionManager( |
03 |
jdbcTemplate.getDataSource() ); |
04 |
TransactionStatus status = null; |
06 |
//null 默认事务属性配置DefaultTransactionDefinition |
07 |
status = tm.getTransaction(null); |
08 |
for(finalString wd: words){ |
10 |
jdbcTemplate.update( insertWordSql, |
11 |
new PreparedStatementSetter(){ |
13 |
public voidsetValues(PreparedStatement pstate) |
15 |
pstate.setString(1, wd) ; |
16 |
pstate.setTimestamp(2, |
17 |
new Timestamp( newDate().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 ...
随机推荐
- Linux shell下批量创建缩略图
一.背景 今天,突然发现手机客户端上的最新新闻缩略图都不显示了,上服务器上看了看, 发现新的新闻图片根本没有生成缩略图. 这套新闻发布系统是很老的程序了,查了一下,问题的原因是不支持png格式的图片, ...
- 查看buffer cache命中率
SQL> select name,value from v$sysstat where name in('db block gets','consistent gets','physical r ...
- 多线程程序设计学习(3)immutable pattern模式
Immutable pattern[坚不可摧模式] 一:immutable pattern的参与者--->immutable(不变的)参与者 1.1:immutable参与者是一个 ...
- android bin目录下的.ap_是神马文件?
resources.ap_ resources翻译过来是资源的意思 应该就是一种中间文件,可以改成rar.zip等压缩文件的类型,里面包含res.AndroidMainfest.xml.resourc ...
- Kafka 设计与原理详解
一.Kafka简介 本文综合了我之前写的kafka相关文章,可作为一个全面了解学习kafka的培训学习资料. 转载请注明出处 : 本文链接 1.1 背景历史 当今社会各种应用系统诸如商业.社交.搜索. ...
- HDU 3333-Turing Tree(BIT好题)
题意: 给你n个数的序列a,q个询问,每个询问给l,r,求在下标i在[l,r]的区间内不含重复数的和 分析: 这类题目觉得很好,很练思维,觉得不太好做. 用BIT维护和,我们可以从前向后扫一遍序列,当 ...
- IOS 类别
在编写面向对象的程序时,你经常希望向现有的类添加一些新的行为:你总是能够为对象提供使用这些新方法的新手段.当希望为现有的类增加新行为时,我们通常会创建子类,但是有时候子类并不方便.例如,你可能会希望为 ...
- 《Python 学习手册4th》 第六章 动态类型简介
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书)“重点笔 ...
- CSS、CSS2和CSS3选择器总结(全部选择器种类及其优先级)
选择器种类罗列: 1.基础的选择器 选择器 含义 示例 * 通用元素选择器,匹配任何元素 * { margin:0; padding:0; } E 标签选择器,匹配所有使用E标签的元素 p { fon ...
- 【C++对象模型】函数返回C++对象的问题
在深入C++对象模型中,对于形如 CObj obj1 = Get(obj2); 的形式,编译器会在将其改变为如下 Get(obj, CObj& obj1); 将赋值操作符左边的变量作为函数的 ...