Spring jdbcTemplate示例
1. 单个插入
2. 批量插入
3. 单个更新
4. 单个删除
5. 批量删除
6. 查询(返回单个对象)
7. 查询(返回集合)
8. 查询(返回基本数据类型)
9. 查询(返回 String)
10. 调用存储过程
11. 批量插入--每次n条
12. 批量更新--每次n条
import java.sql.CallableStatement; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.List; import oracle.jdbc.OracleTypes; import org.springframework.dao.DataAccessException; import org.springframework.jdbc.core.BatchPreparedStatementSetter; import org.springframework.jdbc.core.CallableStatementCallback; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.PreparedStatementCallback; // 1. 单个插入 public int saveImageCharacters(HwCharacter po) throws Exception { StringBuffer sql = new StringBuffer(100); sql.append("INSERT INTO HW_CHARACTER(CHARACTER_ID, IMAGE_ID, CH, "); sql.append("CREATE_TIME) VALUES(?, ?, ?, ?)"); Object[] params = new Object[] { po.getCharacterId(), po.getImageId(), po.getCh(), po.getCreateTime() }; return getJdbcTemplate().update(sql.toString(), params); } // 2. 批量插入 public int batchSave(final List<HwDept> list) throws Exception { StringBuffer sql = new StringBuffer(150); sql.append("INSERT INTO HW_DEPT("); sql.append("DEPT_ID, DEPT_NAME, DEPT_LEVEL, MANAGE_LEVEL, PARENT_ID"); sql.append(")"); sql.append("VALUES(?, ?, ?, ?, ?)"); return getJdbcTemplate().batchUpdate(sql.toString(), new BatchPreparedStatementSetter() { @Override public void setValues(PreparedStatement ps, int i) throws SQLException { ps.setString(1, list.get(i).getDeptId()); ps.setString(2, list.get(i).getDeptName()); ps.setString(3, list.get(i).getDeptLevel()); ps.setString(4, list.get(i).getManageLevel()); ps.setString(5, list.get(i).getParentId()); } @Override public int getBatchSize() { return list.size(); } }).length; } // 3. 更新 public int updateImageCharacters(String ch, String characterId, String imageId) throws Exception { StringBuffer sql = new StringBuffer(200); sql.append("UPDATE HW_CHARACTER SET CH = ? "); sql.append("WHERE CHARACTER_ID = ? AND IMAGE_ID = ?"); Object[] params = new Object[] { ch, characterId, imageId }; return getJdbcTemplate().update(sql.toString(), params); } // 4. 单个删除 public int deleteUserRoleByUserId(String userId) throws Exception { String sql = "DELETE FROM SS_USER_ROLE WHERE USER_ID = ?"; return getJdbcTemplate().update(sql, new Object[] { userId }); } // 5. 批量删除 public int batchDelete(final List<String> idList) throws Exception { String sql = "DELETE FROM HW_DIAGNOSE_RULE_CUST WHERE CUST_RULE_ID = ?"; int[] res = getJdbcTemplate().batchUpdate(sql, new BatchPreparedStatementSetter() { @Override public void setValues(PreparedStatement ps, int i) throws SQLException { ps.setString(1, idList.get(i)); } @Override public int getBatchSize() { return idList.size(); } }); return res.length; } // 6. 查询(返回单个对象) public HwInstrument findById(String id) throws Exception { String sql = "SELECT * FROM HW_INSTRUMENT WHERE INSTRUMENT_ID = ?"; final HwInstrument po = new HwInstrument(); getJdbcTemplate().query(sql.toString(), new Object[] { id }, new RowCallbackHandler() { @Override public void processRow(ResultSet rs) throws SQLException { po.setInstrumentId(rs.getString("INSTRUMENT_ID")); po.setInstrumentModel(rs.getString("INSTRUMENT_MODEL")); po.setInstrumentNo(rs.getString("INSTRUMENT_NO")); po.setInstrumentName(rs.getString("INSTRUMENT_NAME")); po.setFactory(rs.getString("FACTORY")); po.setCreateTime(rs.getTimestamp("CREATE_TIME")); } }); return po; } // 7. 查询(返回集合) public List<HwUseLimit> findUseLimit() throws SQLException, DataAccessException, Exception { StringBuffer sql = new StringBuffer(100); sql.append("SELECT LIMIT_ID, IS_LIMIT, LIMIT_DATE, USE_NOS "); sql.append(" FROM HW_USE_LIMIT"); List<HwUseLimit> list = new ArrayList<HwUseLimit>(10); list = getJdbcTemplate().query(sql.toString(), new RowMapper<HwUseLimit>() { @Override public HwUseLimit mapRow(ResultSet rs, int index) throws SQLException { HwUseLimit ul = new HwUseLimit(); ul.setLimitId(rs.getString("LIMIT_ID")); ul.setIsLimit(rs.getString("IS_LIMIT")); ul.setLimitDate(rs.getString("LIMIT_DATE")); ul.setUseNos(rs.getInt("USE_NOS")); return ul; } }); return list; } // 8. 查询(返回基本数据类型) public int findByLoginName(final String loginName) throws Exception { int count = getJdbcTemplate().execute(new PreparedStatementCreator() { @Override public PreparedStatement createPreparedStatement(Connection conn) throws SQLException { String sql = "SELECT COUNT(ID) FROM SS_USER WHERE LOGIN_NAME = ?"; return conn.prepareStatement(sql); } }, new PreparedStatementCallback<Integer>() { @Override public Integer doInPreparedStatement(PreparedStatement pstmt) throws SQLException, DataAccessException { pstmt.setString(1, loginName); pstmt.execute(); ResultSet rs = pstmt.getResultSet(); rs.next(); return rs.getInt(1); } }); return count; } // 9. 查询(返回 String) public String getCharacterByImageId(String imageId) throws Exception { String sql = "SELECT CH FROM HW_CHARACTER WHERE IMAGE_ID = ?"; Object[] params = new Object[] { imageId }; try { return getJdbcTemplate().queryForObject(sql, params, String.class); } catch (EmptyResultDataAccessException e) { // EmptyResultDataAccessException : 防止返回空值时报异常 return ""; } } 10. 调用存储过程 public String saveNewDatas() throws Exception { log.info("Into BusBarSectionDAOImpl.saveNewDatas()"); // 调用存储过程 String sql = "{CALL P_COMPARE_BUSBARSECTION(?)}"; Object obj = this.jdbcTemplate.execute(sql, new CallableStatementCallback<String>() { @Override public String doInCallableStatement(CallableStatement cs) throws SQLException, DataAccessException { // 设置出参 cs.registerOutParameter(1, OracleTypes.VARCHAR); cs.execute(); // 获取存储过程返回值 return cs.getString(1); } }); log.info("Out of BusBarSectionDAOImpl.saveNewDatas()"); return (String) obj; } 11. 批量插入--每次n条 public int batchSaveNew(final List<BusBarSectionPO> list) throws Exception { log.info("Into BusBarSectionDAOImpl.batchSaveNew(list)"); StringBuffer sql = new StringBuffer(200); sql.append("INSERT INTO T_BUSBARSECTION_NEW("); sql.append("ID, CIMID, NAME, X, Y, HEALTH_SITUATION, INODE, V_VALUE, "); sql.append("V_QUALITY, A_VALUE, A_QUALITY, BAYID, VOLTAGELEVEL_ID, "); sql.append("PATHNAME) "); sql.append(" VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"); sql.append(""); int count = this.jdbcTemplate.execute(sql.toString(), new PreparedStatementCallback<Integer>() { public Integer doInPreparedStatement(PreparedStatement ps) throws SQLException, DataAccessException { int length = list.size(); Connection conn = null; try { conn = ps.getConnection(); conn.setAutoCommit(false); BusBarSectionPO po = null; for (int i = 0; i < list.size(); i++) { po = list.get(i); ps.setString(1, MethodsUtils.getPKValue()); ps.setString(2, po.getCimId()); ps.setString(3, po.getName()); ps.setInt(4, po.getX()); ps.setInt(5, po.getY()); ps.setInt(6, po.getHealthSituation()); ps.setString(7, po.getiNode()); ps.setDouble(8, po.getvValue()); ps.setInt(9, po.getvQuality()); ps.setDouble(10, po.getaValue()); ps.setInt(11, po.getaQuality()); ps.setString(12, po.getBayId()); ps.setString(13, po.getVoltagelevelId()); ps.setString(14, po.getPathName()); ps.addBatch(); // 1000条记录insert一次 if (i % 1000 == 0) { ps.executeBatch(); conn.commit(); } } // 最后insert剩余的数据 ps.executeBatch(); conn.commit(); return length; } catch (SQLException e) { log.error( "Batch save BusBarSectionNew by cimId fail:" + e.getMessage(), e); // 数据回滚 MethodsUtils.connectionRollback(conn); throw e; } catch (DataAccessException e) { log.error( "Batch save BusBarSectionNew by cimId fail:" + e.getMessage(), e); // 数据回滚 MethodsUtils.connectionRollback(conn); throw e; } finally { if (null != conn) { // 如果用<aop:config> 来控制事务,需要把下面一行注掉,否则会报错 conn.setAutoCommit(true); } } } }); return count; 12. 批量更新--每次n条 public int batchUpdateByCimId(final List<BusBarSectionPO> list) throws Exception { log.info("Into BusBarSectionDAOImpl.batchUpdateByCimId(list)"); if (null == list || list.isEmpty()) { log.info("Batch update BusBarSection by cimId,the list is empty."); return 0; } StringBuffer sql = new StringBuffer(200); sql.append("UPDATE T_BUSBARSECTION SET "); sql.append("NAME = ?, X = ?, Y = ?, HEALTH_SITUATION = ?, "); sql.append("INODE = ?, V_VALUE = ?, V_QUALITY = ?, A_VALUE = ?, "); sql.append("A_QUALITY = ?, BAYID = ?, VOLTAGELEVEL_ID = ?, "); sql.append("PATHNAME = ? "); sql.append(" WHERE CIMID = ?"); int count = this.jdbcTemplate.execute(sql.toString(), new PreparedStatementCallback<Integer>() { public Integer doInPreparedStatement(PreparedStatement ps) throws SQLException, DataAccessException { int length = list.size(); Connection conn = null; try { conn = ps.getConnection(); conn.setAutoCommit(false); BusBarSectionPO po = null; for (int i = 0; i < list.size(); i++) { po = list.get(i); ps.setString(1, po.getName()); ps.setInt(2, po.getX()); ps.setInt(3, po.getY()); ps.setInt(4, po.getHealthSituation()); ps.setString(5, po.getiNode()); ps.setDouble(6, po.getvValue()); ps.setInt(7, po.getvQuality()); ps.setDouble(8, po.getaValue()); ps.setInt(9, po.getaQuality()); ps.setString(10, po.getBayId()); ps.setString(11, po.getVoltagelevelId()); ps.setString(12, po.getPathName()); ps.setString(13, po.getCimId()); ps.addBatch(); // 1000条记录更新一次 if (i % 1000 == 0) { ps.executeBatch(); conn.commit(); } } // 最后更新剩余的数据 ps.executeBatch(); conn.commit(); return length; } catch (SQLException e) { log.error( "Batch update BusBarSection by cimId fail:" + e.getMessage(), e); // 数据回滚 MethodsUtils.connectionRollback(conn); throw e; } catch (DataAccessException e) { log.error( "Batch update BusBarSection by cimId fail:" + e.getMessage(), e); // 数据回滚 MethodsUtils.connectionRollback(conn); throw e; } finally { if (null != conn) { // 如果用<aop:config> 来控制事务,需要把下面一行注掉,否则会报错 conn.setAutoCommit(true); } } } }); return count; }
相关推荐
spring JdbcTemplate query方法使用示例,欢迎下载借鉴
spring-1 演示了使用setter方式及构造器方式创建bean,util:list标签创建集合,p标签简化配置 和依赖注入, ...spring-4 演示了spring与JDBCTemplate配合使用 spring-5 演示了声明式事务及使用xml配置文件处理事务
主要介绍了Spring JDBCTemplate原理及使用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
本篇文章主要介绍了Spring 中jdbcTemplate 实现执行多条sql语句示例,可以对多个表执行多个sql语句,有兴趣的可以了解一下。
主要介绍了Spring JdbcTemplate整合使用方法及原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
JavaEE JdbcTemplate的简单示例
一套完成的使用Idea开发环境,采用springboot、jdbcTemplate实现的mysql读取webService完成程序。其中,封装了数据读、写、删除的各种操作;访问webservice时,需要使用token认证。 一套很实用、很难得的的基于java...
主要介绍了spring实现jdbctemplate添加事务支持示例,重写JdbcTemplate增加beginTranstaion,commit,rollback方法,需要的朋友可以参考下
这个本人经常精心调试出来的示例,import 进来就可以使用,例子简单,附有数据库脚本 Struts2+Spring+EasyUI+JDBCTemplate学习源码
主要介绍了详解在spring中使用JdbcTemplate操作数据库的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Spring JDBC Batch更新示例 Example application describes how to perform batch operation with spring JdbcTemplate class.#技术堆栈。 1. Spring核心jdbc模块。 2. H2嵌入式数据库。 3. Gradle构建脚本。 4....
spring-jdbctemplate-example 这是一个Spring Monolith应用程序示例,该示例使用jdbcTemplate连接MySQL数据库并执行反馈操作的操作。测试和构建运行测试(也运行大型测试) ./gradlew clean test 有条件地根据测试...
使用springMvc+SpringJdbcTemplate开发的一个示例,展现了SpringMVC的强大,其中包括Spring的七大控制器及上传下载及拦截器的使用示例,以及使用JdbcTemplate进行数据库的访问操作。
同时讲解了xml和注解两种方式使用Spring的示例。通过Spring的入门程序介绍了Spring的 IoC 和 DI 的概念,介绍了Spring的基本模块。详细介绍了对象创建的细节和依赖注入的几种方式;介绍了如何使用注解完成Spring的...
8.3.8. PetClinic示例 8.4. 更多资源 II. 中间层数据访问 9. 事务管理 9.1. 简介 9.2. 动机 9.3. 关键抽象 9.4. 使用资源同步的事务 9.4.1. 高层次方案 9.4.2. 低层次方案 9.4.3. ...
本文介绍在Spring Boot基础下配置数据源和通过 JdbcTemplate 编写数据访问的示例。感兴趣的朋友跟随脚本之家小编一起学习吧
同时讲解了xml和注解两种方式使用Spring的示例。 通过Spring的入门程序介绍了Spring的IoC和DI的概念,介绍了Spring的基本模块。详细介绍了对象创建的细节和依赖注入的几种方式;介绍了如何使用注解完成Spring...
主要给大家介绍了如何通过5分钟快速学会spring boot整合JdbcTemplate的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用spring boot整合JdbcTemplate具有一定的参考学习价值,需要的朋友们下面来一起...
Spring启动演示 SpringBoot + SpringCloud + SpringSecurity学习过程中的二进制汇总,沉淀记录下学习历程 1.知识点图谱 所有博文集中发布在个人博客网站: 大致规划的内容包括以下章节,希望能用半年到一年(严重...
11.2.1. JdbcTemplate类 11.2.2. NamedParameterJdbcTemplate类 11.2.3. SimpleJdbcTemplate类 11.2.4. DataSource接口 11.2.5. SQLExceptionTranslator接口 11.2.6. 执行SQL语句 11.2.7. 执行查询 11.2.8. 更新...