Product(pid,name,amount,nowAmount):标识,名称,已有数量,当前数量
Trade(id,pid,operType,number):标识,产品标识,操作类型(入库:1,出库:0),数量

Product表中测试数据:

1 苹果 100 0
2 桔子  50 0

Trade表中测试数据:
1 1 1 432
2 1 0 50
3 2 1 20
4 2 0 40
5 1 1 30
6 2 0 20

现要求一条SQL语句更新Product表中nowMount值
语句如下:
SQL两表更新update p set p.nowAmount = p.amount+t.number
SQL两表更新
from Product as p ,(select pid,sum(case operType when '0' then number* (-1)  else number endnumber 
SQL两表更新
from Trade group by pid) as t where t.pid=s.pid
或者
SQL两表更新update p
SQL两表更新
set p.nowAmount= t.number+p.amount
SQL两表更新
from Product as p 
SQL两表更新
inner join (select pid ,sum(case operType when '0' then number* (-1)  else number endas number from Trade group by pid) as t
SQL两表更新
on p.pid=t.pid
SQL两表更新
两者一样执行后Product表:
1 苹果 100 512
2 桔子 50 10

相关文章:

  • 2021-11-04
  • 2021-10-19
  • 2022-12-23
  • 2021-09-01
  • 2021-06-04
  • 2022-12-23
  • 2022-12-23
  • 2022-01-18
猜你喜欢
  • 2022-01-14
  • 2021-12-13
  • 2021-11-30
  • 2021-08-14
  • 2021-11-30
相关资源
相似解决方案