当前位置:  开发笔记 > 编程语言 > 正文

如果以后的记录无法在Laravel 5中添加,如何回滚新记录?

如何解决《如果以后的记录无法在Laravel5中添加,如何回滚新记录?》经验,为你挑选了1个好方法。

在我的控制器中,我有类似于以下代码:

$a = new A();
$a->content = "blah";
$a->save();

$b = new B();
$b->content = "blah2";
$b->a_id = $a->id;
$b->save();

$c = new C();
$c->content = "blah3";
$c->b_id = $b->id;

在那里A,B并且C是所有车型.

如您所见,每个模型分配都依赖于先前正确分配的记录(即C依赖BB依赖C)

我想制作代码,以便如果其中一个新记录失败,它会删除所有以前的记录(即全部或全部).

例如,

如果A保存失败,代码将正常结束

如果B无法保存,则会删除其相应的A记录

如果C无法保存,它删除其相应的BA记录

我该怎么做呢?



1> Marcin Nabia..:

这很简单,使用数据库事务:

DB::transaction(function () {

    $a = new A();
    $a->content = "blah";
    $a->save();

    $b = new B();
    $b->content = "blah2";
    $b->a_id = $a->id;
    $b->save();

    $c = new C();
    $c->content = "blah3";
    $c->b_id = $b->id;

});

这里的所有内容都将自动完成 - 如果上述任何一项失败,结果将与从未运行过的内部代码相同.

参考:Laravel数据库事务

编辑

如果需要传递任何变量,则需要使用如下use构造:

DB::transaction(function () use ($variable1, $variable2) {
  // ...
});

参考:匿名函数

推荐阅读
刘美娥94662
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有