首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果以后的记录没有添加Laravel 5,如何回滚新记录?

如果以后的记录没有添加Laravel 5,如何回滚新记录?
EN

Stack Overflow用户
提问于 2015-12-26 14:05:01
回答 1查看 5.9K关注 0票数 8

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

代码语言:javascript
复制
$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;

其中ABC都是模型。

如您所见,每个模型赋值依赖于正确分配上一条记录(即C依赖于B,而B依赖于C)

我想要使代码,以便如果一个新的记录失败,它删除所有以前的记录(即全部或无)。

例如,

  • 如果A无法保存,代码将优雅地结束。
  • 如果B无法保存,它将删除其相应的A记录。
  • 如果C无法保存,它将删除相应的BA记录。

我该怎么做?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-12-26 14:09:43

非常简单,使用数据库事务:

代码语言:javascript
复制
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构造,如下所示:

代码语言:javascript
复制
DB::transaction(function () use ($variable1, $variable2) {
  // ...
});

参考资料:匿名函数

票数 18
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34472065

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档