mysql 事务及断点

mysql 事务及断点

transaction
savepoint

有时候可能需要在mysql事务中部分提交一些sql命令,这时候断点就派上用场了。
比如:一个事务需要修改id=6的用户的用户名和email,但是事务执行过程中我又不想修改email内容了,这时候就需要只提交用户名的语句。
这里的两个sql语句:

  • 修改用户名

    update users set username='user6' where id=6;
    
  • 修改用户邮箱

    update users set email='user6@163.com' where id=6;
    
  • 如果在事务中只想修改用户名、不想修改用户邮箱,看通过断点如何实现呢?
    如下图所示,是操作的流程:
    事务中使用断点

  • 最后再一次查询该条记录,看一下结果:
    修改结果

从图中我们可以看到 该事务中只修改了用户名,没有修改email, 事务中通过 rollback to savepoint point1 来实现回滚 断点point1之后的语句,这样就达到了我们预期的效果了。

laravel框架支持事务嵌套,其实事务嵌套本身是通过这种断点机制来实现的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值