Share via


row_cumsum()

Beräknar den kumulativa summan av en kolumn i en serialiserad raduppsättning.

Syntax

row_cumsum(term [,omstart] )

Läs mer om syntaxkonventioner.

Parametrar

Namn Typ Obligatorisk Beskrivning
Benämna int, long eller real ✔️ Uttrycket som anger det värde som ska summeras.
Starta bool Anger när ackumuleringsåtgärden ska startas om eller ställas in på 0. Den kan användas för att ange partitioner i data.

Returer

Funktionen returnerar den kumulativa summan av argumentet.

Exempel

I följande exempel visas hur du beräknar den kumulativa summan av de första jämna heltalen.

datatable (a:long) [
    1, 2, 3, 4, 5, 6, 7, 8, 9, 10
]
| where a%2==0
| serialize cs=row_cumsum(a)
a Cs
2 2
4 6
6 12
8 20
10 30

Det här exemplet visar hur du beräknar den kumulativa summan (här, av salary) när data partitioneras (här, efter name):

datatable (name:string, month:int, salary:long)
[
    "Alice", 1, 1000,
    "Bob",   1, 1000,
    "Alice", 2, 2000,
    "Bob",   2, 1950,
    "Alice", 3, 1400,
    "Bob",   3, 1450,
]
| order by name asc, month asc
| extend total=row_cumsum(salary, name != prev(name))
name månad Lön totalt
Alice 1 1000 1000
Alice 2 2000 3000
Alice 3 1400 4400
Bob 1 1000 1000
Bob 2 1950 2950
Bob 3 1450 4400