乖喵咪 2017-11-07 02:42 采纳率: 0%
浏览 862

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

  • 写回答

3条回答 默认 最新

  • huangjian_jj 2017-11-07 03:22
    关注

    不知道你用的是啥数据库,给个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

    评论

报告相同问题?

悬赏问题

  • ¥15 按键修改电子时钟,C51单片机
  • ¥60 Java中实现如何实现张量类,并用于图像处理(不运用其他科学计算库和图像处理库))
  • ¥20 5037端口被adb自己占了
  • ¥15 python:excel数据写入多个对应word文档
  • ¥60 全一数分解素因子和素数循环节位数
  • ¥15 ffmpeg如何安装到虚拟环境
  • ¥188 寻找能做王者评分提取的
  • ¥15 matlab用simulink求解一个二阶微分方程,要求截图
  • ¥30 乘子法解约束最优化问题的matlab代码文件,最好有matlab代码文件
  • ¥15 写论文,需要数据支撑