繁体   English   中英

如何在laravel中使用数据库事务?

[英]How can I use db transaction in laravel?

我尝试这样:

public function destroy($id)
{
    DB::beginTransaction();
    try {
        $product = $this->product_repository->find($id);
        $result = $product->categories()->detach();
        if($result) {
            list($status,$instance) = $this->product_repository->delete($id);
        }
        DB::commit();
        return ['status'=>true,'data'=>$status];
    } catch (\Exception $e) {
        DB::rollback();
        return ['status'=>false, 'message'=>$e->getMessage()];
    }
}

如果执行了代码,则$this->product_repository->delete($id)无法正常工作/无法成功删除。

但这是: $product->categories()->detach(); ,成功/删除成功。

如果删除产品失败,删除类别也失败怎么办?

您不能在transaction中添加return语句以暂停整个过程,并执行DB::rollback()

要切换return ,可以定义一个boolean变量,并在catch异常时将其设置为false

像这样:

public function destroy($id)
{

    $success = true;

    DB::beginTransaction();

    try{

        // Your Code

        $product = $this->product_repository->find($id);
        $result = $product->categories()->detach();

        if($result) {
            list($status,$instance) = $this->product_repository->delete($id);
        }

        DB::commit();

    }catch(\Exception $e){

        DB::rollback();

        $success = false;

    }

    if($success){
        // Return data for successful delete
    }

    else{
        // Return data for unsuccessful delete
    }
}

希望你能理解。

您可以像这样使用它:

$returnResult = [];

DB::beginTransaction();

try {

    ...

    DB::commit();

    $returnResult['status'] = true;
    $returnResult['data'] = $status;
} catch (...) {

    ...

    DB::rollback();

    $returnResult['status'] = true;
    $returnResult['message'] = $e->getMessage();
}

return $returnResult;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM