在我的控制器中有类似于以下代码的代码:
$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依赖于B,而B依赖于C)
我想要使代码,以便如果一个新的记录失败,它删除所有以前的记录(即全部或无)。
例如,
A无法保存,代码将优雅地结束。B无法保存,它将删除其相应的A记录。C无法保存,它将删除相应的B和A记录。我该怎么做?
发布于 2015-12-26 14:09:43
非常简单,使用数据库事务:
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) {
// ...
});参考资料:匿名函数
https://stackoverflow.com/questions/34472065
复制相似问题