Chian男同:减去同表的值(table subtraction)

关于Chian男同gay的问题,在table subtraction中经常遇到, 我坚持使用 Oracle 我的查询,请帮助我。

我坚持使用 Oracle 我的查询,请帮助我。

这是我的桌子:

我想要的结果:

值 = 订单-数量

因此,基于相同 id 和相同 cust 的计算,它们是从之前的行中减去的,如果 id 和 cust 不相同,则它们通常会减去。

提前谢谢

0

我将假设您有另一列,它告诉您应从order列中减去qty的顺序,并将其称为datetime列(但是您可以使用可用的任何列来提供行的确定性排序)。鉴于此,您可以使用分析SUM函数计算value

SELECT id,
       cust,
       datetime,
       order_total,
       qty,
       order_total
         - SUM( COALESCE( qty, 0 ) )
             OVER ( PARTITION BY id, cust, order_total ORDER BY datetime )
         AS value
FROM   table_name

其中,对于示例数据:

CREATE TABLE table_name ( id, cust, datetime, order_total, qty ) AS
SELECT '0001',  'abc',  DATE '2021-01-01', 10000,   2000 FROM DUAL UNION ALL
SELECT '0001',  'abc',  DATE '2021-01-02', 10000,   4000 FROM DUAL UNION ALL
SELECT '0001',  'abc',  DATE '2021-01-03', 10000,   4000 FROM DUAL UNION ALL
SELECT '0002',  'bcd',  DATE '2021-01-01', 5000,    2000 FROM DUAL UNION ALL
SELECT '0003',  'fgh',  DATE '2021-01-01', 3000,    1000 FROM DUAL UNION ALL
SELECT '0004',  'ghj',  DATE '2021-01-01', 5000,    NULL FROM DUAL;

输出:

ID   | CUST | DATETIME  | ORDER_TOTAL |  QTY | VALUE
:--- | :--- | :-------- | ----------: | ---: | ----:
0001 | abc  | 01-JAN-21 |       10000 | 2000 |  8000
0001 | abc  | 02-JAN-21 |       10000 | 4000 |  4000
0001 | abc  | 03-JAN-21 |       10000 | 4000 |     0
0002 | bcd  | 01-JAN-21 |        5000 | 2000 |  3000
0003 | fgh  | 01-JAN-21 |        3000 | 1000 |  2000
0004 | ghj  | 01-JAN-21 |        5000 | null |  5000
db<>fiddlehere
0

你可以试试的-使用lag()

select id,cust,orders,qty,
orders-qty-coalesce(lag(qty) over(partition by id,cust order by qty),0) as value
from tablename

输出:

id          cust        orders  qty    value
0001        abc         10000   2000    8000
0001        abc         10000   4000    4000
0002        bcd         5000    2000    3000
0003        fgh         3000    1000    2000
0

似乎您正在尝试按 id 进行分区,并按 id 和 qty 进行排序。您可以尝试

Select id,  cust,   order,  qty,  order-coalesce(sum(qty) over (partition by id order by id,  qty),0) as value from myTable;

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(737)
昂克赛拉carlife:拉帕克的行减少(reducing a matrix)
上一篇
Cornerstone软件:如何使用CornerstoneDicom查看器加载文件
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 38 93
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 88 12
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 48 55
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 64 64
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 26 34
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 60 44
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 48 56
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 30 11

发表评论

登录 后才能评论

评论列表(39条)