Laravel DB事务怎么使用_Laravel数据库事务回滚操作

发布时间 - 2025-12-21 00:00:00    点击率:
使用DB::transaction()可确保数据库操作原子性,如余额扣减与记录写入同时成功或回滚;支持手动事务控制,适用于复杂逻辑;需避免耗时操作、合理使用行锁,并注意事务生命周期与队列重试问题。

在 Laravel 中使用数据库事务可以确保一组数据库操作要么全部成功,要么全部失败回滚,从而保证数据的一致性。特别是在处理多表写入、更新或删除等关键业务逻辑时,事务非常有用。

1. 使用 DB::transaction() 开启事务

最常见的方式是使用 DB::transaction() 方法包裹需要原子执行的代码块。如果代码块内抛出异常,Laravel 会自动触发回滚;如果没有异常,则自动提交事务。

use Illuminate\Support\Facades\DB;

DB::transaction(function () {
    $user = DB::table('users')->where('id', 1)->lockForUpdate()->first();

    if ($user->balance         throw new \Exception('余额不足');
    }

    DB::table('users')->where('id', 1)->decrement('balance', 50);
    DB::table('transactions')->insert([
        'user_id' => 1,
        'amount' => -50,
        'created_at' => now(),
        'updated_at' => now()
    ]);
});

上面的例子中,如果余额不足抛出异常,两个数据库操作都会被回滚。

2. 手动控制事务(begin、commit、rollback)

你也可以手动开启事务,适用于更复杂的控制逻辑。

DB::beginTransaction();

try {
    DB::table('users')->where('id', 1)->decrement('balance', 50);
    DB::table('logs')->insert([
        'action' => 'deduct_balance',
        'user_id' => 1,
        'created_at' => now(),
        'updated_at' => now()
    ]);

    DB::commit(); // 提交事务
} catch (\Exception $e) {
    DB::rollBack(); // 回滚事务
    // 可以记录日志或重新抛出异常
    report($e);
}

这种方式适合需要捕获异常并进行额外处理的场景。

3. 注意事项与最佳实践

  • 事务中尽量避免耗时操作(如远程请求),以免长时间锁表影响性能
  • 使用 lockForUpdate() 可防止并发修改导致的数据不一致
  • 事务不能跨 HTTP 请求,只在当前请求生命周期内有效
  • 在队列任务中使用事务时,注意任务失败重试可能引发重复提交问题

基本上就这些。合理使用 Laravel 的事务机制,能有效保障关键业务的数据完整性。不复杂但容易忽略细节。


# laravel  # cad  # if  # try  # throw  # catch  # 并发  # function  # table  # 数据库  # http  # 抛出  # 适用于  # 重试  # 是在  # 长时间  # 如果没有  # 或删除  # 只在  # 你也可以  # 最常见 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 中山网站推广排名,中山信息港登录入口?  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  如何在IIS中新建站点并配置端口与物理路径?  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  如何快速搭建个人网站并优化SEO?  js实现获取鼠标当前的位置  JavaScript常见的五种数组去重的方式  Laravel如何集成Inertia.js与Vue/React?(安装配置)  JavaScript如何操作视频_媒体API怎么控制播放  如何在建站之星网店版论坛获取技术支持?  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  浅析上传头像示例及其注意事项  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  详解jQuery中的事件  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  EditPlus中的正则表达式实战(6)  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  Mybatis 中的insertOrUpdate操作  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  如何在云虚拟主机上快速搭建个人网站?  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  简单实现Android文件上传  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  如何快速使用云服务器搭建个人网站?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  python中快速进行多个字符替换的方法小结  如何用狗爹虚拟主机快速搭建网站?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  电商网站制作价格怎么算,网上拍卖流程以及规则?  公司门户网站制作流程,华为官网怎么做?  如何快速搭建高效WAP手机网站?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  原生JS实现图片轮播切换效果  Laravel distinct去重查询_Laravel Eloquent去重方法