JDBC事务的保存点处理

在JDBC的事物处理中,可以应用保存点技术,对一个事物中的处理进行部分提交.
如下示例,三个处理

7,张三减10元
9,李四减10元
8,赵六加10元,

在8的地方出错的话,把8的处理进行提交,使用了保存点技术.

示例代码:

package com.test.tx;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Savepoint;
import java.sql.Statement;

import com.test.jdbc.DBUtil;

public class SavaPointTest {

/**
* @param args
*/
public static void main(String[] args) {

try {

test();
} catch (SQLException e) {
e.printStackTrace();
}
}
/**
* 保存点是可以从 Connection.rollback 方法引用的当前事务中的点。
* 将事务回滚到保存点时,在该保存点之后所作的全部更改都将被撤消。
* @throws SQLException
*/
static void test()throws SQLException{
Connection conn=null;
Statement st=null;
ResultSet rs=null;
Savepoint sp=null;
try{
conn=DBUtil.getConnection();
//初始化不自动提交
DBUtil.setAutoCommit(conn, false);

// 张三减10元
st=conn.createStatement();
String sql="update user set money=money-10 where id=7";
st.executeUpdate(sql);
sp=conn.setSavepoint();//设置了保存点

// 李四加10元
sql="update user set money=money-10 where id=9";
st.executeUpdate(sql);

sql="select money from user where id=8";
rs=st.executeQuery(sql);

float Money=0.0f;
if(rs.next()){
Money=rs.getFloat("money");
}
// 赵六的钱大于1000元(会出现异常)
if(Money>1000){
throw new RuntimeException("已经超过最大值!");
}
sql="update user set money=money+10 where id=8";
st.executeUpdate(sql);

DBUtil.commit(conn);

}catch(RuntimeException e){
if(sp!=null){
//表示提交保存点的事务
conn.rollback(sp);
DBUtil.commit(conn);
}
throw e;
}catch(SQLException e)
{
DBUtil.rollback(conn);
throw e;
}
finally{
DBUtil.close(rs);
DBUtil.close(st);
DBUtil.close(conn);
}

}
}

执行文件后,查看数据库的记录,可以发现张三减少了10元,而,李四减10元和赵六也没加10元的操作并没有进行.

总结:
1,开始要把connection设置成不进行自动提交
2,中间设定保存点
3,回滚的地方要使用保存点
4,最后不要忘记进行commit
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值