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去重方法


项与最佳实践