需求说明:

案例背景:银行的转账过程中,发生意外是在所难免。为了避免意外而造成不必要的损失,使用事务处理的方式进行处理:

A账户现有余额1000元,向余额为200的B账户进行转账500元。可能由于某原因:

A账户在扣除转账金额时发生错误,使用事务回滚来返回到初始状态

A账户成功扣除转账金额后,B账户添加转账金额发生错误,使用事务回滚到初始状态

提示:先建数据表account,字段包括姓名(username)、余额(money),再分别利用事务处理以上两种情况。

  1. #创建账户表
  2. CREATE TABLE IF NOT EXISTS account(
  3. id INT(11)NOT NULL AUTO_INCREMENT PRIMARY KEY,
  4. username VARCHAR(32)NOT NULL,
  5. money DECIMAL(9,2)
  6. )ENGINE=INNODB;
  7. #插入用户数据
  8. INSERT INTO account(username,money)VALUES('A',1000.00);
  9. INSERT INTO account(username,money)VALUES('B',200.00);
  10. /*事务处理*/
  11. #  A账户汇款失败
  12. SELECT * FROM account;
  13. #第一步 关闭事务自动提交模式
  14. SET autocommit=0;
  15. #第二步 开始事务
  16. START TRANSACTION;
  17. #第三步 发现汇款失败,将事务回滚ROLLBACK ||  汇款成功将事件commit
  18. #假设语法错误
  19. UPDATE account SET money=money-500 WHERE username='A';
  20. SELECT * FROM account;
  21. UPDATE account SET money=money+200 WHERE username='B';
  22. ROLLBACK;
  23. #第四步 还原Mysql数据库的的自动提交
  24. SET autocommit=1;
  25. SELECT * FROM account;
  26. /*B接收汇款失败*/
  27. SELECT *FROM account ;
  28. SET autocommit =0;
  29. START TRANSACTION;
  30. UPDATE account SET money=money-500 WHERE username='A';
  31. SELECT * FROM account ;
  32. #假设语法错误
  33. UPDATE account SET money=money+200 WHERE username ='B';
  34. ROLLBACK;
  35. SET autocommit =1;
  36. SELECT * FROM account;
  37. #清除数据
  38. <pre name="code" class="sql">TRUNCATE account;

MySQL事务处理实现方法步骤的更多相关文章

  1. 关于mysql登录异常处理方法 - mysql ERROR 1045 (28000)

    今天在开发过程中遇到了一个很令人头痛的问题?? 使用 百度经验的步骤 [http://jingyan.baidu.com/article/495ba841ef412d38b30edeb2.html]修 ...

  2. mysql事务处理用法与实例详解

    来源:转载  MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关1.MyISAM:不支持事务,用于只读程序提高性能 2.InnoDB:支持ACID事务.行级锁.并发 3.Berke ...

  3. mysql事务处理的意义

    MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关 1.MyISAM:不支持事务,用于只读程序提高性能 .InnoDB:支持ACID事务.行级锁.并发 .Berkeley DB:支 ...

  4. Linux 每天自动备份mysql数据库的方法

    Linux 每天自动备份mysql数据库的方法 作者: 字体:[增加 减小] 类型:转载   linux下为了安全有时候需要自动备份mysql数据库,下面是具体的实现步骤.   /usr/bin为my ...

  5. Windows Server 2003开机自动启动MySQL服务设置方法

    Windows Server 2003开机自动启动MySQL服务设置方法 发布时间:2014-12-19 更新时间:2014-12-24 来源:网络 作者:eaglezhong 关键词: 2003 e ...

  6. 最简便的MySql数据库备份方法

    http://www.kankanews.com/ICkengine/archives/194.shtml 使用MYSQL进行数据库备份,又很正规的数据库备份方法,同其他的数据库服务器有相同的概念,但 ...

  7. MySQL数据库迁移详细步骤(转)

    ========================================================================================== 一.背景简介 == ...

  8. vs连接mysql出错解决方法

    vs连接mysql出错解决方法 先按以下的步骤配置一下: **- (1)打开VC6.0 工具栏Tools菜单下的Options选项.在Directories的标签页中右边的"Show dir ...

  9. 【MySQL笔记】mysql来源安装/配置步骤和支持中国gbk/gb2312编码配置

    不久的学习笔记.分享.我想有很大的帮助谁刚开始学习其他人的 备注:该票据于mysql-5.1.73版本号例如 1. mysql源代码编译/安装步骤 1) 官网下载mysql源代码并解压 2) cd至源 ...

随机推荐

  1. Appium中长按按钮操作

    在一次项目中,appium要对某个按钮进行长按操作(大于2s),类似拍微信小视频,参考网上长按视频会报错 action1 = TouchActions(self.driver) el = self.d ...

  2. Jmeter性能测试实践之java请求

     前言 Apache Jmeter是开源.易用的性能测试工具,之前工作中用过几次对http请求进行性能测试,对jmeter的基本操作有一些了解.最近接到开发的对java请求进行性能测试的需求,所以需要 ...

  3. nginx安装和测试 (已验证)

    进入:/usr/local/nginx 目录注意:为了保证各插件之间的版本兼容和稳定,建议先通过以下版本进行测试验证. 一.下载版本 下载nginx: wget http://nginx.org/do ...

  4. 【ES6】001---module模块------【巷子】

    001.前言 什么是模块化开发?   为了提高代码的复用度,开发人员会按照功能把大量的js代码分成若干文件,这样在多个页面就可以使用同一个文件了.,下面是某个网站的js引用情况 怎么会有这么多js文件 ...

  5. 崩溃block

    [__NSGlobalBlock__ setHidden:]: unrecognized selector sent to instance 0x10dbb9090(null)注释掉 sethidde ...

  6. python redis基本概念简单操作

    转自:http://www.cnblogs.com/melonjiang/p/5342383.html 一.redis redis是一个key-value存储系统.和Memcached类似,它支持存储 ...

  7. Highway Project---zoj3946(最短路SPFA)

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5718 题意: 有n个点 m(n,m<=10^5)条路,现在要建 ...

  8. Git学习-->如何通过Shell脚本实现 监控Gitlab备份整个过程并且通过邮件通知得到备份结果?

    一.背景 Git学习–>如何通过Shell脚本自动定时将Gitlab备份文件复制到远程服务器? http://blog.csdn.net/ouyang_peng/article/details/ ...

  9. 阿里云centos7.2 安装mysql 6.5

    [root@111 ~]# uname -aLinux bxhs 3.10.0-327.22.2.el7.x86_64 #1 SMP Thu Jun 23 17:05:11 UTC 2016 x86_ ...

  10. java-mybaits-00101-基础安装配制

    一.数据库安装 http://jingyan.baidu.com/article/363872ec2e27076e4ba16fc3.html 二.eclipse连接mysql http://jingy ...