首页
学习
活动
专区
圈层
工具
发布

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

前言 如果大家在Laravel中要想在数据库事务中运行一组操作,则可以在 DB facade 中使用 transaction 方法。如果在事务的闭包内抛出异常,事务将会被自动还原。...你不需要担心在使用 transaction 方法时还需要亲自去手动还原或提交事务: DB::transaction(function () { DB::table('users')->update(['...示例介绍 假设有要在数据库中存储一个知识点,这个知识点同时属于两个不同的考点,也就是考点和知识点这两个数据是多对多的关系,那么要实现这种数据结构就需要三个表: 知识点表 wiki: ---- id title...php教程_linux常用命令_网络运维技术】/表 tag: ---- id name 考点知识点关联表 wiki_tag_rel ---- id tag_id wiki_id 现在要开启事务新增Wiki数据...,新增wiki成功后再把它关联到指定的考点上去 (在laravel中使用查询构建器或者Eloquent ORM执行query时,如果失败会返回 IlluminateDatabaseQueryException

2.3K30

完善你的Laravel异常处理

这篇文章我们来简单梳理一下Laravel中提供的异常处理能力,然后讲一些在开发中使用异常处理的实践,如何使用自定义异常、如何扩展Laravel的异常处理能力。...Illuminate\Database\QueryException Laravel中执行SQL语句发生错误时会抛出此异常,它也是使用率最高的异常,用来捕获SQL执行错误,比方执行Update语句时很多人喜欢判断...,最后都会被 \App\Exceptions\Handler捕获到,处理器先上报异常记录到日志文件里然后渲染异常响应再发送响应给客户端。...使用自定义异常 这部分内容其实不是针对 Laravel框架自定义异常,在任何项目中都可以应用我这里说的自定义异常。...UserManagerException的实例,然后通过这个参数将 QueryException实例传递给 PHP异常的堆栈,这提供给我们回溯整个异常的能力来获取更多上下文信息,而不是仅仅只是当前抛出的异常实例的上下文信息

3.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Love beautiful code? We do too.

    PHP框架 Laravel是一个有着美好前景的年轻框架,它的社区充满着活力,同时提供了完整而清晰的文档,而且为快速、安全地开发现代应用提供了必要的功能。...Laravel基于MVC架构,可以满足诸如事件处理、用户身份验证等各种需求,同时通过包管理实现模块化和可扩展的代码,并且对数据库管理有着健壮的支持。...Laravel自带对本地用户的身份验证,并可以使用“remember” 选项来记住用户。此外你还可以引入一些额外参数,例如是否是活跃用户。...所以,你不再需要担心如何将计费系统集成到开发中了。...,队列可以让我们异步处理某些流程而不需要用户在加载页面时长时间的等待。

    4.1K20

    唱衰这么多年,PHP 仍然还是你大爷!

    下面的数据来自 W3 Techs 对前 1000 万个网站的 CMS 使用情况调查[2],每个百分点代表前 1000 万个网站中的 10 万网站。...例如,有 24% 的受访者表示他们的基础设施都是“自托管”,而不是依赖于主流的云服务提供商。...你可以阅读 Basecamp 的文章[18]了解云退出战略是如何为他们每年节省数百万美元的。 大规模 PHP 应用 上述统计数据衡量了不同网站和公司的数量,其中绝大多数是基于 PHP 构建的。...像 Twitch、Disney、New York Times、WWE 和 Warner Bros 这样的公司也在他们的多个项目中使用 Laravel。Laravel 能够轻松应对大规模的应用需求。...(极客旁注:他在 2021 年的现代 PHP 讲座[39]中解释了 Etsy 是如何使用 rsync 进行部署的,就像 Wikipedia 在过去 10 年使用 Scap[40] 一样)。

    2.2K40

    【Laravel系列2.1】先把Laravel跑起来

    先把Laravel跑起来 要使用 Laravel 框架的话,先得使用 Composer ,关于 Composer 相关的文章,我们在最早的系列文章中就有讲解过。...跑起来 安装好 Laravel 之后,我们可以使用一个命令: php artisan key:generate 这个命令是用于生成一个应用密钥,它会为我们的应用会话以及其它加密数据生成一个本应用相关的唯一密钥...当然,这个不是必需的,我们在这里只是提前说明一下,因为后面的入门相关的文章中我们还需要连接数据库、redis 之类的,并测试一下缓存相关的内容。...比如我们一开始不加这个的话,那么访问 Laravel 框架就需要是这样的链接: http://laravel8/index.php 而加上这个 location 重写之后,我们就可以直接使用: http...在这里,也给大家留个作业,找找官方文档,如果我们是虚拟机部署的话,不能指向服务器目录到 public 的情况下,是如何运行 Laravel 框架的呢?

    1.9K30

    使用 Laravel 制定 MySQL 数据库备份计划任务

    背景 几天前,我登录到错误的数据库中然后干掉了 18 000 行线上数据记录。更糟糕的是,我们没有对这个数据库进行备份。然后,我决定编写一个能够自动完成数据库导出并保存到 SQL 文件的脚本。...另外,如果你需要一款功能强大的数据备份系统,你可以看看 这个 扩展。这样我们就无需关注更多的数据库备份细节而仅需将焦点放到数据库导出和导出计划上。...导出命令 使用这个单行 snippet,你可以快速的将数据库导出到 SQL 文件。很多应用使用下面这个命令从数据库导出数据。...原因是这里我们需要使用 Symfony 的 Process 组件 - 而不是简单的调用 shell_exec 函数。这个组件提供了很多好赞的特性。...我们可以使用 Process 组件轻松导出数据库,并将其封装在 artisan 命令中。然后,我们可以快速地为我们的命令设置一个执行周期,而 Laravel 的调度程序将负责剩下的工作。

    3.7K10

    基于 PHPStorm 编辑器的 Laravel 开发

    引言 本文主要讲述在PHPStorm编辑器中如何使用PHPStorm的Laravel插件和Laravel IDE Helper来开发Laravel程序,结合个人积累的一点经验来说明使用PHPStorm编辑器来开发程序还是很顺手的...对Blade模板引擎的支持 使用PHPStorm调试Laravel程序 使用PHPStorm调试Laravel程序 使用PHPStorm的单元测试功能 使用PHPStorm的数据库功能 1、一些准备工作...5、使用PHPStorm的Database链接Laravel程序数据库 PHPStorm中提供了database插件,功能也比较强大,我想用过PHPStorm的应该都知道如何使用,这里聊下一个很好用的一个功能...经常遇到这样的一个情景:数据库装在数据库服务器db.test.com中,但本地是登陆不上去的,但 在开发服务器host.company.com是可以链接数据库服务器的,那如何使用database来连接数据库服务器呢...Terminal中登录到远程服务器,在Terminal上查看修改东西。

    5K80

    【Laravel系列7.2】错误与异常处理

    这种报错页面非常便于我们调试错误,同时,这些错误信息也会同步记录到你的日志文件中,大家可以看看自己的日志里面是不是已经记录了错误信息。...然后再次运行路由进行测试,你会发现日志被记录到了 storage/logs/zyblog.log 文件中,而 laravel.log 文件中没有记录。...但是这个错误信息的格式可能并不是和你系统中定义的格式是相同的。这时候,就可以通过自定义 renderable() 方法中的错误返回格式来实现全部数据接口的格式统一。...现在主要的疑问是在于 Laravel 框架中是如何去捕获这些全局的异常和错误信息的,是使用我们熟悉的 set_error_handler()、set_exception_handler() 这些函数吗?...带着这个问题,我们就来剖析一下 Laravel 源码是如何处理这些情况的。

    4.5K20

    如何在Ubuntu 16.04上使用Deployer自动部署Laravel应用程序

    Deployer通过将应用程序从Git存储库克隆到服务器,使用Composer安装依赖项以及配置应用程序以使您不必手动执行此操作来自动执行部署。这使您可以将更多时间用于开发,而不是上载和配置。...在本教程中,您将自动部署Laravel应用程序,而不会出现任何宕机问题。为此,您将准备将从中部署代码的本地开发环境,然后使用Nginx和MySQL数据库配置生产服务器为该应用程序提供服务。...ssh-keygen -t rsa -b 4096 -f ~/.ssh/gitkey 您可能在本地计算机上有更多SSH密钥,因此请配置SSH客户端以了解连接到Git服务器时要使用的SSH私钥。...我们将设置fastcgi指令以告诉Nginx使用应用程序的实际路径(在遵循符号链接后解析),而不是符号链接。...该应用程序.env在本地计算机上有一个文件,但Laravel的.gitignore文件将其从Git仓库中排除,因为在Git存储库中存储密码等敏感数据不是一个好主意,而且,应用程序需要在服务器上进行不同的设置

    17.5K10

    推荐17-Laravel 中使用 JWT 认证的 Restful API

    在此文章中,我们将学习如何使用 JWT 身份验证在 Laravel 中构建 restful API 。JWT 代表 JSON Web Tokens 。...使用 API 时,只需使用一些参数点击 GET , POST 或其他类型的请求,服务器就会返回 JSON(JavaScript Object Notation) 格式的一些数据,这些数据由客户端应用程序处理...A User 将会使用以下功能 注册并创建一个新帐户 登录到他们的帐户 注销和丢弃 token 并离开应用程序 获取登录用户的详细信息 检索可供用户使用的产品列表 按ID查找特定产品 将新产品添加到用户产品列表中...然后,使用请求中的数据去创建一个新的产品模型。如果,产品成功的写入数据库,会返回成功响应,否则返回自定义的 500 失败响应。...然后,我们把请求中的数据使用 fill 方法填充到产品详情。更新产品模型并保存到数据库,如果记录成功更新,返回一个 200 成功响应,否则返回 500 内部服务器错误响应给客户端。

    14.1K20

    如何选择PHP框架?

    为什么要使用框架而不是原生PHP来开发你的应用程序?下面是使用框架的一些好处: PHP框架令开发更快。...如何选择PHP框架? 在选择一个框架时思考一下以下的问题: 这个框架的特色和功能是什么?它们是不是我所需要的? 这个框架的学习过程要多长? 它的稳定性如何? 这个框架是由核心团队开发和维护的吗?...Yii也使用组件,但它并不是symfony那样的模块化。Laravel与其它两个框架相比,载它的模块化方式没有这么犀利。...性能 任何一个应用程序的性能,只有当它是使用关键数据的实时应用程序时才是重要的。有多少基于Web的应用程序依赖于高性能?不是很多,但框架的性能在许多项目中起着至关重要的作用。...你可以使用一系列的数据库工作,包括NoSQL和DynamoDB。Yii和laravel在这方面也是有用的,但他们支持的数据库比symfony的少。每一个框架支持的数据库如表1所示。 ?

    9.9K90

    Laravel如何优雅的使用Swoole

    这一篇主要聊聊Laravel如何优雅的使用Swoole,其实只需简单3步就可以完成。...这是比较头疼的事情,因为Laravel框架可不是这样的运转的,那如何能与Laravel结合呢?没错,自定义一条Artisan Command,就这么简单。...,就可以把各种业务逻辑写进Laravel框架中,然后就可以使用Laravel提供的各种高效方便的功能了。...STEP 3-发送数据 有两种方法,但都离不开一个缓存kv结构(Laravel自带的Cache功能就够了),保存客户端的地址数据,要不你怎么知道发到哪里去。...这么做的好处就是不需要知道客户端的实际IP地址和端口,在Cache保存客户端的fd标识,直接就发数据。采用这个思路,请记得iptables把端口打开。我自己并没有采用,因为不是长连接我觉得太麻烦。

    2.4K10

    深入浅出 Laravel 的 Facade 外观系统

    外观模式是一种使用频率非常高的结构型设计模式,它通过引入一个外观角色来简化客户端与子系统之间的交互, 为复杂的子系统调用提供一个统一的入口,降低子系统与客户端的耦合度,且客户端调用非常方便。...将使用者与子系统从直接耦合,转变成由「外观」类提供统一的接口给使用者使用,以降低客户端与子系统之间的耦合度。 结构示意图: ?...外观加载原理 在讲解如何使用外观组件之前,我们依旧先去深入分析「外观」组件是如何被 Laravel 加载到项目中的。这一步是 用好「外观」组件的前提。...外观组件配置 所有内置的外观组件的配置数据,同 Laravel 其它服务一样被定义在 config/app.php 文件中。...将使用者与子系统从直接耦合,转变成由「外观」类提供统一的接口给使用者使用,以降低客户端与子系统之间的耦合度。

    3K20

    程序猿必读-防范CSRF跨站请求伪造

    但是事实上并不是如此,很多网站在开发的时候,研发人员错误的认为GET/POST的使用区别仅仅是在于发送请求的数据是在Body中还是在请求地址中,以及请求内容的大小不同。...解析Laravel框架中的VerifyCsrfToken中间件 在Laravel框架中,使用了VerifyCsrfToken这个中间件来防范CSRF攻击。...在页面的表单中使用{{ csrf_field() }}来生成token,该函数会在表单中添加一个名为_token的隐藏域,该隐藏域的值为Laravel生成的token,Laravel使用随机生成的40个字符作为防范...这是因为Laravel认为这三个请求都是请求查询数据的,如果一个请求是使用GET方式,那无论请求多少次,无论请求参数如何,都不应该最数据做任何修改。...Cookie中的XSRF-TOKEN中读取的,因此在每个请求结束的时候,Laravel会发送给客户端一个名为XSRF-TOKEN的Cookie值 $response->headers->setCookie

    3.3K20

    为什么 Laravel 这么优秀?

    因为我们已经完成了数据表中字段的定义、表与表的关系、以及最重要的一步:如何将数据及数据之间的关系写入数据库中,下面简单的来介绍下在 Laravel 是如何完成的。...course_id" in (1) How to save data to database 如何将数据保存到数据库 Laravel Factory 提供了一种很好的方式来 Mock 测试数据,一旦我们定义好...但它却不是最高效的设计。...Cache::get 时就使用的是这里注册的 Cache 对象,在注册阶段不应该向容器中获取值,因为此时服务可能还没有 Ready;启动阶段一般用来控制如何启动你的服务,如你可以在这个阶段中 Connect...Rust 就觉得 Go 狗都不如;在我看来,语言只是实现产品的一种方式,不同的语言在不同的领域有自己的优势,我们应该学习不止一门语言,并尽量了解每一门语言的优缺点,在完成开发时选择自己以及团队合适的,而不是只会写

    6.2K10

    具有嵌套关系的可重用API资源——Laravel5.5

    本文内容主要围绕在 Laravel 5.5 中使用 API 开发的重要步骤,着重介绍如何利用 Laravel 的 API 资源(Resource)和控制器(Controller)进行多因素身份验证(MFA...注:本文受到Laravel创始人Taylor Otwell介绍使用 Laravel5.5 开发API时如何替换 Fractal 的启发。 1....· 修改 .env 文件,使用 SQLite 数据库,并删除其他数据库相关的变量。· 添加或修改 DB_CONNECTION=sqlite 来指定 Laravel 使用 SQLite 作为数据库连接。...简化和逐步进行本文着重于学习如何使用 Resource::collection 而不是手动实例化类,并将关系数据的提供(或不提供)责任委托给控制器。...这暗示着对于数据包含的处理,Laravel 更多地依赖于控制器层面的逻辑,而不是在资源转换层实现。

    5.8K10
    领券