Laravel5中如何使用Eloquent进行数据库事务处理?

2026-05-22 16:155阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计373个文字,预计阅读时间需要2分钟。

Laravel5中如何使用Eloquent进行数据库事务处理?

1. 官方手册介绍如下:在数据库事务中执行连续字符串操作,可使用DB门面的transaction方法。若事务关闭包中抛出异常,事务将自动回滚。若关闭包执行成功,事务将自动提交。

1.官方手册是这样介绍的:

想要在一个数据库事务中运行一连串操作,可以使用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();

注意:使用DB门面的事务方法还可以用于控制查询构建器和 Eloquent ORM 的事务。

阅读全文

本文共计373个文字,预计阅读时间需要2分钟。

Laravel5中如何使用Eloquent进行数据库事务处理?

1. 官方手册介绍如下:在数据库事务中执行连续字符串操作,可使用DB门面的transaction方法。若事务关闭包中抛出异常,事务将自动回滚。若关闭包执行成功,事务将自动提交。

1.官方手册是这样介绍的:

想要在一个数据库事务中运行一连串操作,可以使用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();

注意:使用DB门面的事务方法还可以用于控制查询构建器和 Eloquent ORM 的事务。

阅读全文