Ich versuche, die laufende Summe zu berechnen. Aber es sollte zurückgesetzt, wenn die kumulative Summe größer ist als eine andere Spalte WertReset Laufende Summe basierend auf einer anderen Spalte
create table #reset_runn_total
(
id int identity(1,1),
val int,
reset_val int
)
insert into #reset_runn_total
values
(1,10),
(8,12),(6,14),(5,10),(6,13),(3,11),(9,8),(10,12)
Beispieldaten
+----+-----+-----------+
| id | val | reset_val |
+----+-----+-----------+
| 1 | 1 | 10 |
| 2 | 8 | 12 |
| 3 | 6 | 14 |
| 4 | 5 | 10 |
| 5 | 6 | 13 |
| 6 | 3 | 11 |
| 7 | 9 | 8 |
| 8 | 10 | 12 |
+----+-----+-----------+
Erwartetes Ergebnis
+----+-----+-----------------+-------------+
| id | val | reset_val | Running_tot |
+----+-----+-----------------+-------------+
| 1 | 1 | 10 | 1 |
| 2 | 8 | 12 | 9 | --1+8
| 3 | 6 | 14 | 15 | --1+8+6 -- greater than reset val
| 4 | 5 | 10 | 5 | --reset
| 5 | 6 | 13 | 11 | --5+6
| 6 | 3 | 11 | 14 | --5+6+3 -- greater than reset val
| 7 | 9 | 8 | 9 | --reset -- greater than reset val
| 8 | 10 | 12 | 10 | --reset
+----+-----+-----------------+-------------+
Abfrage:
;WITH cte
AS (SELECT id,
val,
reset_val,
val AS running_total
FROM #reset_runn_total
WHERE id = 1
UNION ALL
SELECT r.*,
CASE
WHEN lag(c.running_total + r.val) over(order by r.id) > lag(r.reset_val) over(order by r.id) THEN r.reset_val
ELSE c.running_total + r.val
END
FROM cte c
JOIN #reset_runn_total r
ON r.id = c.id + 1)
SELECT *
FROM cte
offenbar Wille hinken nicht bekommen die vorherigen Werte irgendwelche Ideen?
Wow .. Kann dies mit Sum() Over() Fenster Aggregat erreicht werden? –
Oder ohne 'Recursive CTE' zu verwenden? –
Sieht aus wie Rekursion kann nicht vermieden werden ... – Serg