gpt4 book ai didi

sql - 如何在 SQL 中查询到特定值的累积总和

转载 作者:行者123 更新时间:2023-12-01 03:33:59 24 4
gpt4 key购买 nike

我有一个看起来像这样的 SQL 表:

Id  Quantity
1 24.857
2 24.84
3 24.881
4 24.823

我需要选择数量的累积总和,直到达到指定的值 - 比如说 50。
因此,对于上表,我需要查询返回前 3 行。 (前两行的数量总和没有达到50,所以我还需要第三行)。

现在我有下面的代码,它很接近但不太正确。此查询的结果仅返回表的前两行,这是不够的。
DECLARE @point INT = 50;

WITH x(Id, Quantity, RowNum, TotalQuantity) AS
(
SELECT
id, quantity, ROW_NUMBER() OVER (ORDER BY id),
SUM(quantity) OVER (ORDER BY id RANGE UNBOUNDED PRECEDING)
FROM inventory
)

SELECT x.Id, x.RowNum, x.Quantity, x.TotalQuantity
FROM x
WHERE x.TotalQuantity <= @point
ORDER BY x.Id

此查询的结果如下:
Id  RowNum  Quantity   TotalQuantity
1 1 24.857 24.857
2 2 24.84 49.697

我觉得我需要一个 WHILE在这里循环,我试图无济于事。

非常感谢任何帮助,谢谢。

最佳答案

当总量>=@point 时,您可以再使用一个 cte 来获得第一行。然后加入现有的 cte。

WITH x(Id, Quantity, RowNum, TotalQuantity) AS
(
SELECT
id, quantity, ROW_NUMBER() OVER (ORDER BY id),
SUM(quantity) OVER (ORDER BY id RANGE UNBOUNDED PRECEDING)
FROM inventory
)
, y as (select min(rownum) as minrownum from x where totalquantity >= @point)
SELECT x.Id, x.RowNum, x.Quantity, x.TotalQuantity
FROM x
JOIN y on x.rownum <= y.minrownum
ORDER BY x.Id

关于sql - 如何在 SQL 中查询到特定值的累积总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36134742/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com