Spring JdbcTemplate小结
2024-07-16 14:29:49 224人阅读
提供了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 { |
02 | public JdbcQueryObject (DataSource ds,String sql){ |
03 | this .setDataSource( ds ); |
05 | this .declareParameter( new Sqlparameter( "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 ; |
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) { |
转自:http://hwqjavaeye.iteye.com/blog/289330
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉:
投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。