手动操作事物的时候怎么应对锁死的情况?

处理死锁
传递第二个可选参数给 transaction 方法,该参数定义在发生死锁时应该重新尝试事务的次数。一旦尝试次数都用尽了,就会抛出一个异常:

DB::transaction(function () {
DB::table('users')->update(['votes' => 1]);

DB::table('posts')->delete();

}, 5);
手动操作事务
如果你想要手动开始一个事务,并且能够完全控制回滚和提交,那么你可以在 DB facade 上使用 beginTransaction 方法:

DB::beginTransaction();
可以通过 rollBack 方法回滚事务:

DB::rollBack();
最后记得要通过 commit 方法提交事务:

DB::commit();

提到了自动处理情况下传第二个值可以处理事物锁死,那手动情况下出现了锁死的情况应该怎么办呢?

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!