MySQL 测试事务实现转账

MySQL 默认开启事务自动提交的

  1. 关闭自动提交
  2. 开启一个事务
  3. 假如成功就提交,失败就回滚
  4. 成功了,持久化到数据库
  5. 开启自动提交
-- MySQL 默认开启事务自动提交的
set autocommit = 0  -- 关闭事务自动提交
set autocommit = 1  -- 开启事务自动提交

-- 手动处理事务

-- 事务开启
START TRANSACTION -- 表示一个事务的开始,从这句话向后的sql都在同一个事务内

-- 提交:持久化(事务成功)
COMMIT
-- 回滚:回到以前的状态(事务失败)
ROLLBACK
-- 事务关闭
set autocommit = 1


SAVEPOINT -- 设置一个事务的保存点
ROLLBACK TO SAVEPOINT -- 回滚到保存点
RELEASE SAVEPOINT -- 撤销保存点

模拟转账场景

CREATE TABLE `account`(
`id` int(3) not null auto_increment,
`name` VARCHAR(10) not null,
`money` DECIMAL(9,2) not null,
PRIMARY key(`id`)
)ENGINE = INNODB DEFAULT charset = utf8

TRUNCATE TABLE account

INSERT into `account` (`name`,`money`) VALUES ('SAS',4750),('凤凰战士',900)

-- 模拟转账事务
set autocommit = 0

START TRANSACTION
UPDATE account set money=money-500 where `name` = 'SAS'
UPDATE account set money=money+500 where `name` = '凤凰战士'
COMMIT;
ROLLBACK;
set autocommit = 1

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值