首页 > 其他 > 详细

事务管理模型(银行转账)

时间:2019-08-16 01:02:00      阅读:124      评论:0      收藏:0      [点我收藏+]
package cn.itcast.jdbc;

import cn.itcast.util.JDBCUtils;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

/**
* @author newcityman
* @date 2019/8/15 - 23:39
* 演示事务
*/
public class JDBCDemo09 {
public static void main(String[] args) {
Connection conn = null;
PreparedStatement stmt1=null;
PreparedStatement stmt2=null;
try {
// 1、获取连接
conn = JDBCUtils.getConnection();
// 2、开启事务
conn.setAutoCommit(false);
String sql1="update account set balance =balance-? where id=?";
String sql2="update account set balance =balance+? where id=?";

stmt1 = conn.prepareStatement(sql1);
stmt2 = conn.prepareStatement(sql2);

stmt1.setDouble(1,500);
stmt1.setInt(2,1);

stmt2.setDouble(1,500);
stmt2.setInt(2,2);

stmt1.executeUpdate();
// int i=1/0;
stmt2.executeUpdate();

conn.commit();
} catch (SQLException e) {
e.printStackTrace();
try {
conn.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}
}
}
}

事务管理模型(银行转账)

原文:https://www.cnblogs.com/newcityboy/p/11361321.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!