sql 一对多汇总求和

kuaidi.ping-jia.net  作者:佚名   更新日期:2024-07-31
SQL怎么对某一列进行求和 并计数?一句sql语句可以写么

select sum(id4),count(*) from a_temp ;
可以一句SQL就直接查询得到列的和以及记录数。
该SQL中sum(id4)是列id4的总和,
count(*)是得到的数据总行数。


是否可以理解为A表+B表中的内容减去C表中NAME相同的,并且加上C表中A表和B表都没有的?可以这样做
create Table #TableA(ID int,NAME varchar(5),TNUM int)
create Table #TableB(ID int,NAME varchar(5),TNUM int)
create Table #TableC(ID int,NAME varchar(5),TNUM int)

insert into #TableA values (1,'AA',10),(2,'BB',20),(3,'CC',30)
insert into #TableB values (1,'AA',40),(2,'BB',50),(4,'DD',60)
insert into #TableC values (1,'AA',50),(2,'BB',70),(3,'CC',30),(5,'EE',80)

select * into #Temp from #TableA union all select * from #TableB

merge #Temp t1 using #TableC t2
on t1.NAME = t2.NAME
when matched then
delete
when not matched then
insert values (t2.ID,t2.NAME,-t2.TNUM);

select * from #temp
#temp中的内容最终为:
ID NAME TNUM
----------- ----- -----------
5 EE -80
4 DD 60
其中AA,BB,CC在C表中出现,即被筛除,保留DD。
EE未出现在A,B表中,结果记为负值。
可以写一个存储过程,把#temp的内容返回即可。

select DOC_NUM,max(business_qty),sum(PURCHASE_ARRIVE_NO_business_qty),sum(PURCHASE_RETURN_NO_business_qty)
from 表
group by DOC_NUM