zoukankan      html  css  js  c++  java
  • MySQL教程122-MySQL为什么需要事务?

    在银行业务中,有一条记账原则,即有借有贷,借贷相等。为了保证这种原则,每发生一笔银行业务,就必须确保会计账目上借方科目和贷方科目至少各记一笔,并且这两笔账要么同时成功,要么同时失败。如果出现只记录了借方科目,或者只记录了贷方科目的情况,就违反了记账原则。会出现记错账的情况。

    在银行的日常业务中,只要是同一银行(如都是中国农业银行,简称农行),一般都支持账户间的直接转账。因此,银行转账操作往往会涉及两个或两个以上的账户。在转出账户的存款减少一定金额的同时,转入账户的存款就要增加相应的金额。

    下面,在 MySQL 数据库中模拟一下上述提及的转账问题。

    假如要从张三的账户直接转账 500 元到李四的账户。首先需要创建账户表,存放用户张三和李四的账户信息。创建账户表和插入数据的 SQL 语句和运行结果如下所示:

    mysql> CREATE TABLE bank(
        -> customerName VARCHAR(20),   #用户名
        -> currentMoney DECIMAL(10,2)    #当前余额
        -> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
    Query OK, 0 rows affected (0.26 sec)
    
    mysql> INSERT INTO bank (customerName,currentMoney) VALUES('张三',1000);;
    Query OK, 1 row affected (0.07 sec)
    
    mysql> INSERT INTO bank (customerName,currentMoney) VALUES('李四',1);
    Query OK, 1 row affected (0.08 sec)

    查询 bank 数据表的 SQL 语句和运行结果如下:

    mysql> SELECT * FROM bank;
    +--------------+--------------+
    | customerName | currentMoney |
    +--------------+--------------+
    | 张三         |      1000.00 |
    | 李四         |         1.00 |
    +--------------+--------------+
    2 rows in set (0.02 sec)

    结果显示,张三和李四两个账户的余额总和为 1000+1=1001 元。

    下面开始模拟实现转账功能。从张三的账户直接转账 500 元到李四的账户,可以使用 UPDATE 语句分别修改张三的账户和李四的账户。张三的账户减少 500 元,李四的账户增加 500 元, SQL 语句如下所示:

    /*转账测试:张三转账给李四 500 元*/
    #张三的账户少 500 元,李四的账户多 500UPDATE bank SET currentMoney = currentMoney-500 WHERE customerName = '张三';
    UPDATE bank SET currentMoney = currentMoney+500 WHERE customerName = '李四';

    正常情况下,执行以上的转账操作后,余额总和应保持不变,仍为 1001 元。但是,如果在这个过程的其中一个环节出现差错,如在张三的账户减少 500 元之后,这时发生了服务器故障,李四的账户没有立即增加 500 元,此时,第三方读取到两个账户的余额总和变为 500+1=501 元,即账户总额间少了 500 元。

    MySQL 为了解决此类问题,提供了事务。事务可以将一系列的数据操作捆绑成一个整体进行统一管理,如果某一事务执行成功,则在该事务中进行的所有数据更改均会提交,成为数据库中的永久组成部分。如果事务执行时遇到错误,则就必须取消或回滚。取消或回滚后,数据将全部恢复到操作前的状态,所有数据的更改均被清除。

    MySQL 通过事务保证了数据的一致性。上述提到的转账过程就是一个事务,它需要两条 UPDATE 语句来完成。这两条语句是一个整体,如果其中任何一个环节出现问题,则整个转账业务也应取消,两个账户中的余额应恢复为原来的数据,从而确保转账前和转账后的余额总和不变,即都是 1001 元。

  • 相关阅读:
    一、JQuery选择器
    二、HelloMaven-第一个Maven项目
    一、maven的简介和环境搭建
    Junit源码
    五、spring和Hibernate整合
    JS 冒泡排序从学到优化
    JS小案例(基础好烦恼少)----持续更新
    JS+PHP实现用户输入数字后取得最大的值并显示为第几个
    将博客搬至CSDN
    HTML表单相关
  • 原文地址:https://www.cnblogs.com/no-celery/p/13577106.html
Copyright © 2011-2022 走看看