29 } 提供了JdbcTemplate 来封装数据库jdbc操作细节: 包括: 数据库连接[打开/关闭] , 异常转义 , SQL执行 , 查询结果的转换 使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操
29 |
}
|
提供了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()); |
08 |
} |
09 |
} |
10 |
); |
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 )); |
7 |
} |
8 |
} |
9 |
); |
01 |
List
uGroup = jdbcTemplate.query( "SELECT
id,name,.. FROM tblname WHERE igroup=1" , |
02 |
new RowMapper(){ |
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 )); |
07 |
return user
; |
08 |
} |
09 |
} |
10 |
}; |
3)使用JdbcTemplate 便捷方法
1 |
List
uNames = jdbcTemplate.queryForList( "SELECT
name FROM tblname WHERE id>?" , |
2 |
new Integer
[]{ 5 },
String. class ); |
1 |
List "SELECT
id, name FROM tblname WHERE id>?" , |
2 |
new Integer
[]{ 5 }); |
3 |
for (Map |
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 |
int uNum
= 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( new Sqlparameter( "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 = new SqlFunction(
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 |
new DataSourceTransactionManager( |
03 |
jdbcTemplate.getDataSource()
); |
04 |
TransactionStatus
status = null ; |
05 |
try { |
06 |
//null
默认事务属性配置DefaultTransactionDefinition |
07 |
status
= tm.getTransaction( null ); |
08 |
for ( final String
wd: words){ |
09 |
try { |
10 |
jdbcTemplate.update(
insertWordSql, |
11 |
new PreparedStatementSetter(){ |
12 |
13 |
public void setValues(PreparedStatement
pstate) |
14 |
throws SQLException
{ |
15 |
pstate.setString( 1 ,
wd) ; |
16 |
pstate.setTimestamp( 2 , |
17 |
new Timestamp( new Date().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 |
}
|