SQL中两个表按时间分客户汇总问题,求助!

图片说明

如图,有两个表,一个是发货一个是退货,现在SQL要查询按月份及客户分类的汇总数据,怎么写?

谢谢各位解答,我现在已经发现不用转换日期了,如下面语句中的ABSID就是过账期间,直接引用即可。但是问题来了:我想用Order by对TD.LineSum这个字段按大小排序,应该怎么做?。

select sum(S1.WS) as WSS,S1.CrdName,S1.ABSID,S1.OwnerName
from

(Select sum(TD.LineSum) as WS,TM.CrdName,TM.ABSID,TM1.OwnerName
From SASal TM
LEFT JOIN SASalA TD on TD.DocEntry=TM.DocEntry
LEFT JOIN BPClt TM1 on TM1.CltID=TM.CrdID
Where TM.DocDate>=@DF and TM.DocDate<=@DT
Group by TM.CrdName,TM.ABSID,TM1.OwnerName

Union All

Select sum(-TD.LineSum) as WS,TM.CrdName,TM.ABSID,TM1.OwnerName
From SABak TM
LEFT JOIN SABakA TD on TD.DocEntry=TM.DocEntry
LEFT JOIN BPClt TM1 on TM1.CltID=TM.CrdID
Where TM.DocDate>=@DF and TM.DocDate<=@DT
Group by TM.CrdName,TM.ABSID,TM1.OwnerName)S1
Group by S1.CrdName,S1.ABSID,S1.OwnerName

不知道你用的是啥数据库,给个oracle的参考一下吧,

select to_char(t.月份,'yyyy-mm') as 月份,
t.客户,
t.金额汇总) - b.金额汇总) as 金额
from 发货单 t left join 退货单 b on t.客户 = b.客户
where t.月份 = b.月份
group by to_char(t.月份,'yyyy-mm'),t.客户
order by to_char(t.月份,'yyyy-mm')

无非就是日期转换问题,mysql的话好像是把to_char改成date_format

一楼就可以,就是一个分组左联的过程。on后面可以跟两个条件就不用where条件了

发货单与退货单需要查询参数相同,数值为正负数,所以可以直接先单个表汇总,再把汇总后两个表合并 单标汇总如下:

 select month(月份) as moth,客户 ,sum(price)  from  发货单
group by month(月份),客户