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 】
相关推荐:
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
Laravel storage目录权限问题_Laravel文件写入权限设置
香港服务器网站推广:SEO优化与外贸独立站搭建策略
进行网站优化必须要坚持的四大原则
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
如何在Tomcat中配置并部署网站项目?
如何在企业微信快速生成手机电脑官网?
Laravel如何处理CORS跨域请求?(配置示例)
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
googleplay官方入口在哪里_Google Play官方商店快速入口指南
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
网站制作软件有哪些,制图软件有哪些?
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
Laravel怎么使用Intervention Image库处理图片上传和缩放
Laravel如何配置任务调度?(Cron Job示例)
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
长沙做网站要多少钱,长沙国安网络怎么样?
如何在腾讯云免费申请建站?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
JavaScript实现Fly Bird小游戏
如何在云主机快速搭建网站站点?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
Laravel Docker环境搭建教程_Laravel Sail使用指南
js代码实现下拉菜单【推荐】
laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何用5美元大硬盘VPS安全高效搭建个人网站?
Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南
如何用低价快速搭建高质量网站?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
如何快速辨别茅台真假?关键步骤解析
Laravel如何保护应用免受CSRF攻击?(原理和示例)
JavaScript中的标签模板是什么_它如何扩展字符串功能
Laravel如何与Docker(Sail)协同开发?(环境搭建教程)
Laravel如何实现API版本控制_Laravel API版本化路由设计策略
移动端脚本框架Hammer.js
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能
Android自定义listview布局实现上拉加载下拉刷新功能
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
javascript日期怎么处理_如何格式化输出
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
使用C语言编写圣诞表白程序


项与最佳实践