Yah*_*din 6 php sql laravel laravel-5 laravel-5.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;
Run Code Online (Sandbox Code Playgroud)
在那里A,B并且C是所有车型.
如您所见,每个模型分配都依赖于先前正确分配的记录(即C依赖B并B依赖C)
我想制作代码,以便如果其中一个新记录失败,它会删除所有以前的记录(即全部或全部).
例如,
A保存失败,代码将正常结束B无法保存,则会删除其相应的A记录C无法保存,它删除其相应的B和A记录我该怎么做呢?
Mar*_*łek 14
这很简单,使用数据库事务:
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;
});
Run Code Online (Sandbox Code Playgroud)
这里的所有内容都将自动完成 - 如果上述任何一项失败,结果将与从未运行过的内部代码相同.
参考:Laravel数据库事务
编辑
如果需要传递任何变量,则需要使用如下use构造:
DB::transaction(function () use ($variable1, $variable2) {
// ...
});
Run Code Online (Sandbox Code Playgroud)
参考:匿名函数