事务处理,批量更新

今天使用Spring的batchUpdate批量更新的时候,发现它并没有事务处理,这里我写了个方法来做一下事务处理,嘿嘿!

 

	JdbcTemplate jt = (JdbcTemplate) InitSpring.getInstance().contex.getBean("jdbcTemplate");
	TransactionTemplate transactionTemplate = (TransactionTemplate) InitSpring.getInstance().contex.getBean("transactionTemplate");
 
	/**
	 * 事务处理,批量更新List<String> String是SQL语句
	 * 
	 * @return
	 */
	public boolean batchUpdate(final List<String> sqlList) {
		try {
			transactionTemplate.execute(new TransactionCallback() {
				public Object doInTransaction(TransactionStatus status) {
					for (String sql : sqlList) {
						jt.update(sql);
					}
					return null;
				}
			});
		} catch (Exception e) {
			e.printStackTrace();
			return false;
		}
		return true;
	}

 

Spring的配置文件:

	<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
		<property name="dataSource" ref="dataSource" />
	</bean>
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource" />
	</bean>
	
	<bean id="transactionTemplate" class="org.springframework.transaction.support.TransactionTemplate">
      <property name="transactionManager">
        <ref bean="transactionManager"/>
      </property>
      <property name="propagationBehaviorName" value="PROPAGATION_REQUIRED"></property>
  	</bean>

 测试类:

		System.out.println("SQL语句装载完毕,开始导入向数据库导入数据……");
		this.batchUpdate(list);
		System.out.println("导入完毕!");
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值