现在我们要做一个转账系统。

第一章:创建一张新的表格(用户银行账户表格)

在之前的JDBC_01数据库中新增一个表格,名字为:Account

  其中,有id、银行卡号、银行密码、账户余额。

创建表格代码:

create table account (id int not null auto_increment,username varchar(45),password varchar(45),money int,primary key(id));

创建好后,使用命令desc account;查看表格结构。

接下来,添加两个银行账户,那么就创建小猪和小牛两个人吧。

insert into account(username,password,money) values('小猪','123456',1000);

insert into account(username,password,money) values('小牛','654321',5000);

小猪有1000块钱,小牛有5000

好了,回到IDEA。

第二章:创建基本的转账功能

创建两个执行语句,一个是扣钱,一个是加钱。

public static boolean transform(String name1,String name2,int money){
Connection con = null;
PreparedStatement pstmt1 = null;
PreparedStatement pstmt2 = null;
ResultSet rs = null;
try {
con = JDBCUtils.getConnection(); String sql = "update account set money = money-? where username = ?";
pstmt1 = con.prepareStatement(sql); pstmt1.setInt(1, money);
pstmt1.setString(2, name1); pstmt1.executeUpdate();//返回影响的行数 sql = "update account set money = money+? where username = ?";
pstmt2 = con.prepareStatement(sql); pstmt2.setInt(1, money);
pstmt2.setString(2, name2); pstmt2.executeUpdate();//返回影响的行数 return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtils.close(con, pstmt, rs);
}
return false;
}

转账代码在main中调用:

transform("小猪","小牛",100);

转账前:

转账后:

第三章:为什么要创建事务操作

在转账的过程中,有可能系统会发生错误,断电等等,

这样就有可能导致转钱的人的钱扣了,但是后面的代码就没有执行了,这样收款方就收不到钱了。

比如我们:

空指针错误(随便举的一个例子)

这样就导致小猪少了一百,但是小牛却没有进账。

第四章:使用事务功能Commit

事务操作,简单的说,

就是把一大堆需要一起执行的SQL语句打包好,再一起发送到数据库中。

这样就不会出现上面所说的,

前一条SQL语句发过去数据库了,但因为Java程序死机了,导致后面一个紧跟着的SQL语句没发过去。

使用方法:

在关键的代码(需要一起执行的SQL语句)前添加

con.setAutoCommit(false);

//关键代码,如转账

con.commit();

现在转账代码即:

public static boolean transform(String name1,String name2,int money){
Connection con = null;
PreparedStatement pstmt1 = null;
PreparedStatement pstmt2 = null;
ResultSet rs = null;
try {
con = JDBCUtils.getConnection(); con.setAutoCommit(false); String sql = "update account set money = money-? where username = ?";
pstmt1 = con.prepareStatement(sql); pstmt1.setInt(1, money);
pstmt1.setString(2, name1); pstmt1.executeUpdate();//返回影响的行数 //上面代码已经扣钱了
//在这里发生了一些意外
String a = null;
a.charAt(2);
//抛出空指针错误
//下面代码就不执行了 sql = "update account set money = money+? where username = ?";
pstmt2 = con.prepareStatement(sql); pstmt2.setInt(1, money);
pstmt2.setString(2, name2); pstmt2.executeUpdate();//返回影响的行数 con.commit(); return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
JDBCUtils.close(con, pstmt1, rs);
}
return false;
}

我们再执行转账。

即使程序依旧报出空指针错误,但是钱的问题不会发生了。

【JDBC】学习路径7-转账-commit事务操作的更多相关文章

  1. SSM(spring mvc+spring+mybatis)学习路径——1-2、spring事务管理

    目录 1-2 Spring事务管理 概念介绍 事务回顾 事务的API介绍 Spring 事务管理 转账案例 编程式事务管理 声明式事务管理 使用XML配置声明式事务 基于tx/aop 使用注解配置声明 ...

  2. Java -- JDBC 学习--通过Statement进行数据库更新操作

    通过 JDBC 向指定的数据表中插入一条记录. 1. Statement: 用于执行 SQL 语句的对象 1). 通过 Connection 的 createStatement() 方法来获取 2). ...

  3. 使用JDBC进行数据库的事务操作(2)

    本篇将讲诉如何使用JDBC进行数据库有关事务的操作.在上一篇博客中已经介绍了事务的概念,和在MySQL命令行窗口进行开启事务,提交事务以及回滚事务的操作. 似乎事务和批处理都可以一次同时执行多条SQL ...

  4. 使用JDBC进行数据库的事务操作(1)

    本篇讲述数据库中非常重要的事务概念和如何使用MySQL命令行窗口来进行数据库的事务操作.下一篇会讲述如何使用JDBC进行数据库的事务操作. 事务是指数据库中的一组逻辑操作,这个操作的特点就是在该组逻辑 ...

  5. spring学习(三) ———— spring事务操作

    前面一篇博文讲解了什么是AOP.学会了写AOP的实现,但是并没有实际运用起来,这一篇博文就算是对AOP技术应用的进阶把,重点是事务的处理. --wh 一.jdbcTemplate 什么是JdbcTem ...

  6. JDBC 学习笔记(十一)—— JDBC 的事务支持

    1. 事务 在关系型数据库中,有一个很重要的概念,叫做事务(Transaction).它具有 ACID 四个特性: A(Atomicity):原子性,一个事务是一个不可分割的工作单位,事务中包括的诸操 ...

  7. JDBC 学习笔记(二)—— 大数据+存储过程+批处理+事务管理

    本文目录:       1.使用JDBC处理大数据        2.使用JDBC处理大文本        3.使用JDBC处理二进制数据        4.Oracle中大数据处理        5 ...

  8. Java框架spring学习笔记(十七):事务操作

    事务操作创建service和dao类,完成注入关系 service层叫业务逻辑层 dao层单纯对数据库操作层,在dao层不添加业务 假设现在有一个转账的需求,狗蛋有10000元,建国有20000元,狗 ...

  9. Java -- JDBC 学习--事务

    数据库事务 在数据库中,所谓事务是指一组逻辑操作单元,使数据从一种状态变换到另一种状态.为确保数据库中数据的一致性,数据的操纵应当是离散的成组的逻辑单元:当它全部完成时,数据的一致性可以保持,而当这个 ...

随机推荐

  1. [pwn基础]动态链接原理

    目录 [pwn基础]动态链接原理 动态链接概念 动态链接调用so例子 GOT(全局偏移表) got表劫持小实验 PLT(延迟绑定) PLT概念 延迟绑定(PLT表) 实战学习 [pwn基础]动态链接原 ...

  2. Museui 图标速览,再也不用担心网页打不开了

    更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_44519496/article/details/119328173

  3. Java实用类(五) -Math类和指定范围的随机数

    1.Math类 java.lang.Math类提供了常用的数学运算方法和两个静态常量E(自然对数的底数) 和PI(圆周率) // 绝对值 System.out.println(Math.abs(-3. ...

  4. 使用C++的ORM框架QxORM

    QxORM中,我们用的最多的无非是这两点 官方表述是这样的: 持久性: 支持最常见的数据库,如 SQLite.MySQL.PostgreSQL.Oracle.MS SQL Server.MongoDB ...

  5. UiPath邮件自动化

    在UiPath中下载Outlook电子邮件附件Outlook电子邮件自动化教程UiPathRPAhttps://www.bilibili.com/video/BV1oK411L72T 在UiPath中 ...

  6. HashMap的实现原理?如何保证HashMap线程安全?

    A:HashMap简单说就是它根据建的hashcode值存储数据的,大多数情况下可以直接定位到它的值,因而具有很快的访问速度,但遍历的顺序是不确定的. B:HashMap基于哈希表,底层结构由数组来实 ...

  7. 解决方案:可以ping别人,但是别人不能ping我

    背景:我在写分布式爬虫项目时遇到了slave端无法ping通我的master,我的master可以ping通slave.我将master的防火墙关闭后slave可以ping了,但是这不是解决办法.于是 ...

  8. 记一次 .NET 差旅管理后台 CPU 爆高分析

    一:背景 1. 讲故事 前段时间有位朋友在微信上找到我,说他的 web 系统 cpu 运行一段时候后就爆高了,让我帮忙看一下是怎么回事,那就看吧,声明一下,我看 dump 是免费的,主要是锤炼自己技术 ...

  9. 图片64base转码与解码

    场景一:图片转码成base64,传输,接收后解码成png等格式图片 import base64 # 读取图片,转换为base64编码格式 with open("F:\Archer\pictu ...

  10. HashSet 添加/遍历元素源码分析

    HashSet 类图 HashSet 简单说明 HashSet 实现了 Set 接口 HashSet 底层实际上是由 HashMap 实现的 public HashSet() { map = new ...