MySQL事务处理实现方法步骤
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,需求说明:案例背景:银行的转账过程中,发生意外是在所难免。为了避免意外而造成不必要的损失,使用事务处理的方式进行处理:A账户现有余额1000元,向余额为200的B账户进行转账500元。可能由于某原因:
千家信息网最后更新 2025年01月18日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安全错误
数据库的锁怎样保障安全
数据库索引碎片
网络技术基础中的rlp
制衣软件开发
服务器路由器交换机关系
免费ftp服务器带数据库
奇益互联网科技
关系数据库支持什么模型
江北安卓软件开发平台
在服务器上无法连接到打印机
共享软件开发
辽宁数字化城管软件开发电话
1.2数据库的逻辑设计
为什么没有数据库缓存一体
服务器加cpu需要提升卡吗
国家网络安全宣传背景图
网易服务器爆炸
网络技术知识展板
广东社交软件开发收费
服务器禁用ntlmv1
上海品牛网络技术有限公司
堆叠交换机切换访问服务器
防范化解网络安全风险工作要求
北京联讯无线网络技术有限公司
pfam数据库怎么找
网络安全事件分为哪四级
苏州移动软件开发流程
如何实现云数据库
ip代理软件开发
数据库float格式
猕猴桃 网络安全