事务之保存点(savepoint)

如果开启一个事务,已经写了很多语句,突然发现执行完上一语句时发现语句写错了。你只好使用rollback语句让数据库恢复到事务开启之前的状态。以前写完的语句也需要重新执行。所以mysql数据库的作者提出了保存点(savepoint)的概念。开启事务后在执行语句后面打几个点,我们调用rollback语句就会回滚到指定的点。而不是回到事务执行之前的样子。

定义保存点的语法如下:

SAVEPOINT 保存点的名称;

当我们想回滚到某个保存点时,可以使用下边的语句。(WORK和SAVEPOINT可有可无)

ROLLBACK [WORK] TO [SAVEPOINT]

不过如果rollback后面不跟保存点的名称,事务就会回滚到执行之前的状态。

如果想删除某个保存点可以使用下面的语句。

RELEASE SAVEPOINT 保存点名称;

下面举个例子来说明保存点的用法。张三向猫爷转账2块钱。在执行完扣除张三2块钱处打一个保存点。

select * from account;
idnamebalance
1狗哥11
2猫爷2
3张三10

 

 

 

 

 

#开启事务
begin;

update account set balance =balance-2 where id=3;


savepoint s1; #一个保存点


select * from account;

idnamebalance
1狗哥11
2猫爷2
3张三8

 

 

 

 

 

 UPDATE account SET balance = balance + 1 WHERE id = 2; #更新错了

回滚事务到保存点;

rollback to s1; #回滚到保存点


select * from account;
idnamebalance
1狗哥11
2猫爷2
3张三10
  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值