在批处理中使用事务

为了方便认识什么叫做事务,在此举一个例子,最明显的例子银行的转账业务,大家再熟悉不过了,从汇款账户中减去指定金额,并将该金额添加至收款账户中,但是如果在转账的过程中发生程序错误或系统断电等意外情况,就可能导致汇款账户的余额已经减少而收款账户的余额没有增加。这时就需要应用事务对问题进行处理,本实例简单模拟银行转账系统进行账户余额的转账。
在数据库系统中,实际上每一条SQL语句都是一个事务。当这条语句执行时,要么执行成功,要么执行失败,退回最初状态。不过,如果执行一组SQL语句的操作,当其中某些步骤出现错误是,就不能还原最初的状态了,这是就需要用到数据库的事务处理机制。
在JDBC中事务处理的一般步骤如下:
① 调用setAutoCommit()方法设置自动提交方式为false。语法:setAutoCommit(false)。
setAutoCommit总的来说就是保持数据的完整性,一个系统的更新操作可能要涉及多张表,需多个SQL语句进行操作, 循环里连续的进行插入操作,如果你在开始时设置了:conn.setAutoCommit(false); 最后才进行conn.commit(),这样你即使插入的时候报错,修改的内容也不会提交到数据库,而如果你没有手动的进行setAutoCommit(false);出错时就会造成,前几条插入,后几条没有,所以设置setAutoCommit()尤为关键。
② 在异常处理中完成数据回滚。语法rollback();
③ 手动提交SQL语句。语法conn.commit();
④ 调用setAutoCommit(true)方法恢复原来提交方式
批处理主要是分两步:
第一:将要执行的SQL语句保存,利用addBatch()方法将要执行的SQL先保存起来,先不执行
第二:执行所以SQL语句。利用executeBatch()方法所有执行SQL语句
1.在项目中创建类Demo,在该类中定义操作数据库的各种方法,然后定义获取账户表中的所账户的方法,该方法以list集合对象作为返回值,具体代码如下:
public List selectClipDetail() {
//定义保存查询结果list集合
Listlist=new ArrayList();
try {
conn=UtilDemo.getConnection();//获取数据库连接
//执行SQL语句
ps=conn.prepareStatement(“select CardNumber from PW_ClipDetail”);
re=ps.executeQuery();
while(re.next()){//遍历结果集
ClipDetail c=new ClipDetail();
c.setCardNumber(re.getString(“CardNumber”));
list.add©;
}
} catch (SQLException e) {

		e.printStackTrace();
	}
	return list;

}
2.在Demo类中定义转账方法Batch()。该方法包含两个String的参数与一个float类型的参数分别用来指定转账的账户与转入的账户以及转账的金额,具体代码如下:
public boolean Batch(String NumberId, String NumberId2, float money) throws Exception {
boolean bath=false;
try {
conn=UtilDemo.getConnection();
conn.setAutoCommit(false);//设置自动提交方式为false
java.sql.Statement cs=null;//定义Statement对象
cs=conn.createStatement();
//修改转账表中数据
//cs.addBatch() 将sql语句保存起来,先不执行
cs.addBatch(“update PW_ClipDetail set ClipMoney=ClipMoney-”+ money +" where CardNumber="+ NumberId +" “);
cs.addBatch(“update PW_ClipDetail set ClipMoney=ClipMoney+”+ money +” where CardNumber="+ NumberId2 +" ");
cs.executeBatch();//执行批处理中所有的sql语句
conn.commit();//手动提交事务
conn.setAutoCommit(true);//恢复提交方式
conn.close();
bath=true;
} catch (SQLException e) {
conn.rollback();//异常处理中完成数据回滚
e.printStackTrace();
}
return bath;
}
运行结果如下图所示:
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle数据库使用MyBatis进行高效的百万级批量插入可以使用批处理操作,以下是实现步骤: 1. 配置MyBatis的批处理属性: 在MyBatis的配置文件添加以下属性: ``` <settings> <setting name="jdbcTypeForNull" value="NULL" /> <setting name="cacheEnabled" value="true" /> <setting name="lazyLoadingEnabled" value="true" /> <setting name="aggressiveLazyLoading" value="false" /> <setting name="multipleResultSetsEnabled" value="true" /> <setting name="useColumnLabel" value="true" /> <setting name="useGeneratedKeys" value="false" /> <setting name="autoMappingBehavior" value="PARTIAL" /> <setting name="autoMappingUnknownColumnBehavior" value="WARNING" /> <setting name="defaultExecutorType" value="SIMPLE" /> <setting name="defaultStatementTimeout" value="25000" /> <setting name="defaultFetchSize" value="100" /> <setting name="safeRowBoundsEnabled" value="false" /> <setting name="mapUnderscoreToCamelCase" value="false" /> <setting name="localCacheScope" value="SESSION" /> <setting name="jdbcTypeForNull" value="NULL" /> <setting name="flushCacheEnabled" value="false"/> <setting name="batch" value="true"/> </settings> ``` 其,最后一行 `batch` 属性表示开启批处理模式。 2. 编写Mapper文件: 在Mapper文件编写批量插入的SQL语句,例如: ``` <insert id="batchInsert" parameterType="java.util.List"> insert into user (id, name, age) values <foreach collection="list" item="user" separator=","> (#{user.id}, #{user.name}, #{user.age}) </foreach> </insert> ``` 其,`parameterType` 指定了传入参数的类型为 `List`,`foreach` 标签表示对传入的List进行遍历,生成批量插入的SQL语句。 3. 编写Java代码: 在Java代码使用MyBatis的 `SqlSession` 对象执行批量插入操作,示例如下: ``` SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); List<User> userList = new ArrayList<>(); // 添加一百万条测试数据 for (int i = 0; i < 1000000; i++) { User user = new User(); user.setId(i+1); user.setName("user"+i); user.setAge(20+i); userList.add(user); } userMapper.batchInsert(userList); sqlSession.commit(); ``` 其,`SqlSessionFactory` 是MyBatis的会话工厂对象,`UserMapper` 是Mapper接口对象,`userList` 是需要批量插入的数据列表,最后需要调用 `commit()` 方法提交事务。 这样,就可以使用MyBatis进行高效的百万级批量插入操作了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值