ThinkPHP6中的事务操作,菜鸟如何理解?

2023-04-1712:30:43后端程序开发Comments1,003 views字数 902阅读模式

事务操作对很多新人来说,可能有点陌生,即使看了ThinkPHP6官方手册中事务操作的部分,也仍然不知所解。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

下面就给大家介绍下事务操作。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

一、先说说使用场景。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

假设我需要给朋友转账1000元钱,正常的业务逻辑是:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

1、银行从我的账户中扣除1000元文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

2、银行给朋友账户加上1000元。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

如果一切顺利,则转账成功!文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

那么问题来了,如果我不小心把银行账户输错,导致银行查找不到我输入的银行账户,但是这个时候钱已经从我的账户扣除了,如何处理呢?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

我们生活中经常说“如果钱打不过去,银行会退回来的”,就是这个意思。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

2、事务操作定义。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

那么通过上面的例子,我们理解下到底什么是事务操作,事务指的是逻辑上的一组操作,组成这组操作的各个单元要么全都成功,要么全都失败。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

就如上面的打钱例子,要么打钱成功,如果不成功,需要把我的钱退回来,也就是返回到初始状态,也叫做“回滚”。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

3、ThinkPHP6中的事务操作。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

我们理解了事务操作的使用场景,那么在ThinkPHP6中如何使用呢?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

Db::transaction(function () {
    Db::table('think_user')->insert(['name'=>'aaa']);
    Db::table('think_user')->delete(1);
});

我们看上面的例子,只有当我们插入记录成功的时候才会做删除操作,如果插入不成功,不会做删除操作。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

比如我们故意写错一个字段name1,数据表中没有name1该字段,插入程序不会执行成功,那么下面的删除语句没有问题,但是他依然不会执行。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

除此之外,我们还可以手动控制事务。看下面代码:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

// 启动事务
Db::startTrans();
try {
    Db::table('think_user')->find(1);
    Db::table('think_user')->delete(1);
    // 提交事务
    Db::commit();
} catch (\Exception $e) {
    // 回滚事务
    Db::rollback();
}

以上就是ThinkPHP6中的事务操作的内容,通过咱们实际生活中的例子讲解,大家对事务操作就可以很好的理解了。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

php中文网认证作者:“王雪芹”文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/34593.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/34593.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定