MySQL 默认开启事务自动提交的
- 关闭自动提交
- 开启一个事务
- 假如成功就提交,失败就回滚
- 成功了,持久化到数据库
- 开启自动提交
-- 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