代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Java
】
用数据库事务控制语句模拟银行汇款过程
作者:
fengbin8606
/ 发布于
2014/12/19
/
409
import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.sql.Statement; import jdbc.util.DBUtil; public class Trans { public static void main(String[] args) { Trans tran = new Trans(); tran.transfer(1, 2, 500); tran.print("select * from account"); } /** * 汇款 * @param from 汇款人 * @param to 接受人 * @param amount 汇款金额 */ public void transfer(int from, int to, double amount) { String sql1 = "update account set balance=balance-? where id=?"; String sql2 = "update account set balance=balance+? where id=?"; // 在汇款以后,如果汇出帐号的余额为负数,就抛出 余额不足异常,自动回滚到原始状态。 String sql3 = "select balance from account where id=?"; Connection conn = null; try{ conn = DBUtil.getConnection(); conn.setAutoCommit(false); //开启事务 PreparedStatement ps1 = conn.prepareStatement(sql1); ps1.setDouble(1,amount); ps1.setInt(2, from); ps1.executeUpdate(); PreparedStatement ps2 = conn.prepareStatement(sql2); ps2.setDouble(1,amount); ps2.setInt(2, to); ps2.executeUpdate(); //检查余额 PreparedStatement ps3 = conn.prepareStatement(sql3); ps3.setInt(1, from); ResultSet rs = ps3.executeQuery(); double balance = 0; while(rs.next()){ balance = rs.getDouble("balance"); } if(balance<0){ throw new Exception("余额不足"); } rs.close(); ps1.close();ps2.close();ps3.close(); conn.commit(); //提交事务 }catch(Exception e){ e.printStackTrace(); try { conn.rollback(); //回滚事务 } catch (SQLException e1) { e1.printStackTrace(); } }finally{ DBUtil.close(conn); } } public void print(String sql){ Connection conn = null; try{ conn = DBUtil.getConnection(); Statement st = conn.createStatement(); ResultSet rs = st.executeQuery(sql); ResultSetMetaData meta = rs.getMetaData(); int cols = meta.getColumnCount(); for(int i=1;i<=cols;i++){ System.out.print(meta.getColumnName(i)+" "); } System.out.println(); while(rs.next()){ for(int i=1;i<=cols;i++){ Object data = rs.getObject(i); System.out.print(data+" "); } System.out.println(); } rs.close(); st.close(); }catch(SQLException e){ e.printStackTrace(); }finally{ DBUtil.close(conn); } } }
试试其它关键字
数据库事务
银行汇款
同语言下
.
List 切割成几份 工具类
.
一行一行读取txt的内容
.
Java PDF转换成图片并输出给前台展示
.
java 多线程框架
.
double类型如果小数点后为零则显示整数否则保留两位小
.
将图片转换为Base64字符串公共类抽取
.
sqlParser 处理SQL(增删改查) 替换schema 用于多租户
.
JAVA 月份中的第几周处理 1-7属于第一周 依次类推 29-
.
java计算两个经纬度之间的距离
.
输入时间参数计算年龄
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
fengbin8606
贡献的其它代码
(
7
)
.
查找数组中最大值最小值
.
Extjs5 自动生成列 权限
.
统计一句话中每个字符的个数
.
BAE使用Redis作为内存缓存
.
用数据库事务控制语句模拟银行汇款过程
.
随机加法游戏
.
商品保质期
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3