现有两条线程会同时进入执行该方法,执行流程结果

  • 线程 A 进入该方法,执行完第 1 行,查询用户 ID 为 1 的用户余额为 50。

  • 线程 B 进入该方法,执行完第 1 行,查询用户 ID 为 1 的用户余额为 50。

  • 线程 A 执行完第 2 行,将 50 - 50 的结果 0 更新到了数据库。

  • 线程 B 执行完第 2 行,将 50 - 50 的结果 0 更新到了数据库。

请问这个执行完是余额是-50吗

看你怎么写,如果是代码里50-50是0,如果是sql里写50-50是-50