laravel 中事务的使用

Posted LvFish

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了laravel 中事务的使用相关的知识,希望对你有一定的参考价值。

在laravel5.3中使用事务

可以直接使用DB::beginTransaction();使用

前提是数据库表必须支持事务,目前mysql中表类型只有InnoDb支持事务

想要在一个数据库事务中运行一连串操作,可以使用DB门面的transaction方法,如果事务闭包中抛出异常,事务将会自动回滚。如果闭包执行成功,事务将会自动提交。使用transaction方法时不需要担心手动回滚或提交:

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

手动使用事务

如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用DB门面的beginTransaction方法:

DB::beginTransaction();

你可以通过rollBack方法回滚事务:

DB::rollBack();

最后,你可以通过commit方法提交事务:

DB::commit();

以上是关于laravel 中事务的使用的主要内容,如果未能解决你的问题,请参考以下文章

Laravel:如何在控制器的几种方法中重用代码片段

片段事务中的实例化错误

Laravel - 从数据库事务关闭中获取变量

laravel特殊功能代码片段集合

Android从后台堆栈中删除事务

使用viewpager的片段事务返回空白视图