jdbc处理银行转账事务
生活随笔
收集整理的這篇文章主要介紹了
jdbc处理银行转账事务
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一、建立余額表(bal_tab,余額必須大于0)、交易表(bus_tab)
二、建立轉賬事務類BankBusiness.java
import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException;import cn.yanchengdai.util.DataSourceForPool;/*** 銀行轉賬事務處理示例* @author Administrator**/ public class BankBusiness {/*** 處理轉賬的方法* @param transferMoney*/public void testTrans(int transferMoney) {/*從數據庫連接池中獲取數據庫連接*/Connection conn = DataSourceForPool.getConnection();/*交易表中插入兩條數據*/String sql1 = "insert into bus_tab values(?,?,?,?,?)";String sql2 = "insert into bus_tab values(?,?,?,?,?)";/*余額表中更新余額*/String sql3 = "update bal_tab set balance=(balance-?) where id = ?";String sql4 = "update bal_tab set balance=(balance+?) where id = ?";/*聲明PreparedStatement變量*/PreparedStatement ps1 = null;PreparedStatement ps2 = null;PreparedStatement ps3 = null;PreparedStatement ps4 = null;try {/*設置自動關閉connetion自動提交*/conn.setAutoCommit(false);ps1 = conn.prepareStatement(sql1);ps1.setInt(1, 1);ps1.setInt(2, transferMoney);ps1.setString(3, "轉出");ps1.setDate(4, new java.sql.Date(System.currentTimeMillis()));ps1.setInt(5, 100);ps2 = conn.prepareStatement(sql2);ps2.setInt(1, 2);ps2.setInt(2, transferMoney);ps2.setString(3, "轉入");ps2.setDate(4, new java.sql.Date(System.currentTimeMillis()));ps2.setInt(5, 200);ps3 = conn.prepareStatement(sql3);ps3.setInt(1, transferMoney);ps3.setInt(2, 100);ps4 = conn.prepareStatement(sql4);ps4.setInt(1, transferMoney);ps4.setInt(2, 200);ps1.executeUpdate();ps2.executeUpdate();ps3.executeUpdate();ps4.executeUpdate();/*以上順利執行,則提交事務*/conn.commit();System.out.println("轉賬成功");} catch (SQLException e) {System.out.println("轉賬失敗,事務回滾!");try {conn.rollback();} catch (SQLException e1) {e1.printStackTrace();}e.printStackTrace();}finally {try {ps4.close();ps3.close();ps2.close();ps1.close();conn.close();} catch (SQLException e) {e.printStackTrace();}}} }三、測試類TestTransaction.java
import java.util.Scanner;import cn.yanchengdai.dao.BankBusiness;public class TestTransaction {public static void main(String[] args) {Scanner in = new Scanner(System.in);System.out.println("請輸入轉賬金額:");int transfer = in.nextInt();System.out.println("銀行正在轉賬中,請稍后。。。");new BankBusiness().testTrans(transfer);}}四、測試結果
當轉賬20000時,余額=0,違反了檢查約束,事務回滾,兩張表中數據不變:
當轉賬9000時,顯示轉賬成功。
轉賬記錄:
余額表:
總結
以上是生活随笔為你收集整理的jdbc处理银行转账事务的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: N皇后问题12 · N-Queens
- 下一篇: 可测性设计技术