laravel 并发控制写法-涉及资金


一、两种方案正面对比

方案 A:事务 + SELECT ... FOR UPDATE

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

    if ($user->balance >= $amount) {
        DB::table('users')
            ->where('id', $id)
            ->update(['balance' => $user->balance - $amount]);
    }
});

方案 B:原子 UPDATE

复制代码
$affected = DB::update(
    'UPDATE users
     SET balance = balance - ?
     WHERE id = ? AND balance >= ?',
    [$amount, $id, $amount]
);

二、为什么方案 B 效率更高

1️⃣ SQL 次数:1 次 vs 2 次

方案 SQL
FOR UPDATE SELECT + UPDATE
原子 UPDATE UPDATE(1 次)

少一次:

  • 网络 IO

  • SQL 解析

  • 执行计划

  • 锁切换

👉 在高并发下差距非常明显


2️⃣ 锁的持有时间:极短

FOR UPDATE
  • 锁从 SELECT 开始

  • 一直到事务提交

  • 中间可能跑 PHP 逻辑、日志、异常处理

原子 UPDATE
  • 锁只在 一条 UPDATE 执行期间

  • 几乎是毫秒级

👉 锁时间越短,并发吞吐越高


3️⃣ 锁的范围更小、更可控

复制代码
WHERE id = ? AND balance >= ?
  • 主键精确命中

  • 只锁 1 行

  • 不产生多余间隙锁

而:

复制代码
SELECT ... FOR UPDATE
  • 如果条件不严谨

  • 可能锁多行 / 锁范围扩大

  • 更容易死锁


三、并发安全性:谁更强?

维度 FOR UPDATE 原子 UPDATE
防超扣
防并发
防逻辑漏洞 ⚠️ 依赖代码 ✅ 数据库保证
出错概率 较高 极低

👉 原子 UPDATE 把风险从「代码层」下沉到「数据库层」


四、那 FOR UPDATE 什么时候才值得用?

✅ 适合 FOR UPDATE 的场景

  1. 必须先读,再做复杂决策

    复制代码
    余额 + 状态 + 规则 + 多字段计算
  2. 要锁多行 / 多表

    • 订单 + 库存 + 账户

    • 且逻辑无法合并成一条 SQL

  3. 需要保证"读到的就是将要修改的"


❌ 不适合 FOR UPDATE 的场景

  • 单字段扣减(余额 / 库存 / 次数)

  • 能写成:

    复制代码
    UPDATE ... WHERE 条件
  • 高并发、低延迟要求

👉 这正是支付扣款场景


FINALLY:

💰 钱 / 库存 / 次数

原子 UPDATE

复制代码
UPDATE ... SET x = x - ? WHERE x >= ?

📦 复杂业务状态流转

transaction + FOR UPDATE

相关推荐
半夜修仙2 分钟前
RabbitMQ中如何保证消息的可靠性传输
java·分布式·中间件·rabbitmq·github·java-rabbitmq
Flittly4 分钟前
【AgentScope Java新手村系列】(3)工具系统
java·spring boot·spring
mN9B2uk176 分钟前
大数据量高并发的数据库优化
服务器·数据库·oracle
吴声子夜歌6 分钟前
Java——多线程编程技巧
java·多线程
Database_Cool_9 分钟前
PolarSearch AutoETL:让数据库内置搜索不再需要搬运工
数据库
AI行业学习19 分钟前
CC-Switch v3.16.1 官方下载 | 安装配置详细教程【2026.6.10】
java·开发语言·vue.js·python·mysql·eclipse·html
cui178756840 分钟前
物业费收缴困局的破题之路:2026年社区商业逻辑的底层重构
大数据·数据库·人工智能
不负岁月无痕1 小时前
C++ 模板核心内容与高频面试题汇总
java·开发语言·c++
Flittly1 小时前
【AgentScope Java新手村系列】(2)第一个Agent-基础对话
java·spring boot·spring·ai
是发财不是旺财1 小时前
Hermes 网关四层权限控制方案:让 AI Agent 安全地查数据库
数据库·安全·agent·openclaw·hermes