MySQL事务处理实现方法步骤
发表于:2025-11-06 作者:千家信息网编辑
千家信息网最后更新 2025年11月06日,需求说明:案例背景:银行的转账过程中,发生意外是在所难免。为了避免意外而造成不必要的损失,使用事务处理的方式进行处理:A账户现有余额1000元,向余额为200的B账户进行转账500元。可能由于某原因:
千家信息网最后更新 2025年11月06日MySQL事务处理实现方法步骤
需求说明:
案例背景:银行的转账过程中,发生意外是在所难免。为了避免意外而造成不必要的损失,使用事务处理的方式进行处理:
A账户现有余额1000元,向余额为200的B账户进行转账500元。可能由于某原因:
A账户在扣除转账金额时发生错误,使用事务回滚来返回到初始状态
A账户成功扣除转账金额后,B账户添加转账金额发生错误,使用事务回滚到初始状态
提示:先建数据表account,字段包括姓名(username)、余额(money),再分别利用事务处理以上两种情况。
#创建账户表 CREATE TABLE IF NOT EXISTS account( id INT(11)NOT NULL AUTO_INCREMENT PRIMARY KEY, username VARCHAR(32)NOT NULL, money DECIMAL(9,2) )ENGINE=INNODB; #插入用户数据 INSERT INTO account(username,money)VALUES('A',1000.00); INSERT INTO account(username,money)VALUES('B',200.00); /*事务处理*/ # A账户汇款失败 SELECT * FROM account; #第一步 关闭事务自动提交模式 SET autocommit=0; #第二步 开始事务 START TRANSACTION; #第三步 发现汇款失败,将事务回滚ROLLBACK || 汇款成功将事件commit #假设语法错误 UPDATE account SET money=money-500 WHERE username='A'; SELECT * FROM account; UPDATE account SET money=money+200 WHERE username='B'; ROLLBACK; #第四步 还原Mysql数据库的的自动提交 SET autocommit=1; SELECT * FROM account; /*B接收汇款失败*/ SELECT *FROM account ; SET autocommit =0; START TRANSACTION; UPDATE account SET money=money-500 WHERE username='A'; SELECT * FROM account ; #假设语法错误 UPDATE account SET money=money+200 WHERE username ='B'; ROLLBACK; SET autocommit =1; SELECT * FROM account; #清除数据 TRUNCATE account;
备注:
使用IF NOT EXISTS创建数据表的解释
事务
账户
数据
转账
处理
汇款
错误
余额
金额
意外
成功
数据表
状态
语法
事件
原因
备注
姓名
字段
情况
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
游改尚为什么服务器连接失败
杨浦区app软件开发服务
360路由器服务器管理员密码
大发软件开发公司电话
阿里云 pd数据库与传统数据库
软件开发逆向工程
南阳网络安全答题竞赛
衡水人社怎么显示服务器异常
罗宾森数据库
广电网络技术一年培训计划
ios数据库加密
数据库深度性能
服务器防护措施方案
公共ftp服务器地址
如何查看数据库报文
信息网络安全总结
网吧服务器关掉局域网防护
软件开发如何进行账务处理
互联网带来的新科技
数据库锁的级别和安全度
软件开发属于哪些专业
系统软件开发环境介绍
海外服务器ip地址和密码
一组服务器租金
调度自动化网络安全防护新闻
数据库发展历史分为哪几个阶段
企业内部文件服务器
上层服务器
达梦数据库用什么客户端好
csv导入数据库主键冲突