• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Laravel如何使用数据库事务及捕获事务失败后的异常详解

    前言

    如果大家在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。如果闭包运行成功,事务将被自动提交。

    你不需要担心在使用 transaction 方法时还需要亲自去手动还原或提交事务:

    DB::transaction(function () {
     DB::table('users')->update(['votes' => 1]);
    
     DB::table('posts')->delete();
    });

    手动操作事务

    如果你想手动处理事务并对还原或提交操作进行完全控制,则可以在 DB facade 使用 beginTransaction 方法:

    DB::beginTransaction();

    你也可以通过 rollBack 方法来还原事务:

    DB::rollBack();

    最后,可以通过 commit 方法来提交这个事务:

    DB::commit();

    注意: DB facade 的事务方法也可以用来控制 查询语句构造器 及 Eloquent ORM 的事务。

    示例介绍

    假设有要在数据库中存储一个知识点,这个知识点同时属于两个不同的考点,也就是考点和知识点这两个数据是多对多的关系,那么要实现这种数据结构就需要三个表:

    知识点表 wiki:

    ---------------------------------------
    id  title    content
    --------------------------------------- 

    考点表 tag:

    -------------------
    id  name
    -------------------

    考点知识点关联表 wiki_tag_rel

    ----------------------------------
    id   tag_id  wiki_id
    ----------------------------------

    现在要开启事务新增Wiki数据,新增wiki成功后再把它关联到指定的考点上去

    (在laravel中使用查询构建器或者Eloquent ORM执行query时,如果失败会返回 Illuminate\Database\QueryException 异常)

    ?php
    
    namespace App\Http\Controllers;
    
    use Illuminate\Http\Request;
    use Illuminate\Database\QueryException;
    use App\Wiki;
    
    class TestController extends Controller
    {
     //用DB facade的事务方法控制 查询语句构建器的事务
     public function storeWiki(Request $request)
     {
      DB::beginTransaction();
      try {
       $tagIds = explode(',', $request->get('tag_id'));
       $wiki_id = DB::table('wiki')->insertGetId([
        'title' => $request->get('title'),
        'content' => $request->get('content')
       ]);
    
       $relationData = [];
       foreach($tagIds as $tagId) {
        $data = ['wiki_id' => $wiki_id, 'tag_id' => $tagId];
        $relationData[] = $data;
       }
       DB::table('wiki_tag_rel')->insert($relationData);
       DB::commit();
      } catch(\Illuminate\Database\QueryException $ex) {
       DB::rollback();
       return \Response::json(['status' => 'error', 'error_msg' => 'Failed, please contact supervisor']);
      }
      
      return \Response::json(['status' => 'ok']);
     }
    
    
     //用DB facade的事务方法控制 Eloquent ORM的事务
     public function createWiki(array $data)
     {
      DB::beginTransaction();
      try {
       $tagIds = explode(',', $data['tag_id']);
       $newWiki = Wiki::create([
        'title' => $data['title'],
        'content' => $data['content']
       ]);
       //Wiki和Tag两个Model使用了belongsToMany建立了多对多的关系
       //通过attach方法来附加wiki和tag的关系(写入中间表)
       $newWiki->tags()->attach($tagIds);
       DB::commit();
      } catch(QueryException $ex) {
       DB::rollback();
       return \Response::json(['status' => 'error', 'error_msg' => 'Failed, please contact supervisor']);
      }
    
      return \Response::json(['status' => 'ok']);
      }
    
    }

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • Laravel框架数据库CURD操作、连贯操作总结
    • PHP开发框架Laravel数据库操作方法总结
    • Laravel5.7 数据库操作迁移的实现方法
    • Laravel框架实现多数据库连接操作详解
    • Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
    • PHP的Laravel框架结合MySQL与Redis数据库的使用部署
    • Laravel实现数据库迁移与支持中文的填充
    • Laravel创建数据库表结构的例子
    • Laravel如何同时连接多个数据库详解
    • laravel框架数据库配置及操作数据库示例
    上一篇:PHP实现实时生成并下载超大数据量的EXCEL文件详解
    下一篇:基于php流程控制语句和循环控制语句(讲解)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    Laravel如何使用数据库事务及捕获事务失败后的异常详解 Laravel,如何,使用,数据库,