李宜 2013-10-31 12:52 采纳率: 100%
浏览 2329
已采纳

SQL Oracle 查询数据,汇总数据 oracle数据查询

序号 数量 日期
1 1 20131001
2 1 20131007
3 8 20131008
4 9 20131009
5 5 20131010
使用SQL语句查询出这样的结果:
1 1 20131001
2 2 20131007
3 9 20131008
4 17 20131009
5 22 20131010
也就是数量这一列为当天数量加上前一天的数量,谢谢

  • 写回答

1条回答

  • zj003 2013-10-31 13:26
    关注

    假设存储这些数据的表名为cal_amount,sunmber表示序号,amount表示数量,sdate表示日期,以下语句为一点拙见,望抛砖引玉。。。

    with cal_amount_temp as
    (select c.sunmber + 1 as sunmber, c.amount, c.sdate as sdate
    from cal_amount c)

    select a.sunmber, a.amount + nvl(b.amount, 0) as amount, a.sdate
    from cal_amount a
    left join cal_amount_temp b
    on a.sunmber = b.sunmber
    order by a.sunmber

    但是,如果说“数量这一列为当天数量加上前一天的数量”,那么楼主结果中的最后一行为什么是22,而不是14?

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作