WINDOW
gælder for:beregnet kolonneberegnet tabelMeasurevisualiseringsberegning
Returnerer flere rækker, der er placeret inden for det angivne interval.
Syntaks
WINDOW ( from[, from_type], to[, to_type][, <relation> or <axis>][, <orderBy>][, <blanks>][, <partitionBy>][, <matchBy>][, <reset>] )
Parametre
Begreb | Definition |
---|---|
from |
Angiver, hvor window starter. Det kan være et hvilket som helst DAX udtryk, der returnerer en skalar value.
Funktionsmåden afhænger af parameteren from_type : - If from_type er REL, value antallet af rækker (negativ or) fremad (positiv value) fra den aktuelle række for at hente den first række i window.
– If from_type er ABS, andfrom er positiv, er det positionen for starten af window fra starten af partitionen. Indeksering er 1-baseret. 1 betyder f.eks., at window starter fra starten af partitionen.
If
from er negativ, er det placeringen af starten af window fra slutningen af partitionen. -1 betyder den last række i partitionen. |
from_type |
Ændrer funktionsmåden for parameteren from . Mulige values er ABS (absolut) and REL (relativ). Standard er REL. |
to |
Samme som from , men angiver slutningen af window. Rækken last er inkluderet i window. |
to_type |
Samme som from_type , men ændrer funktionsmåden for to . |
relation |
(Valgfrit) Et tabeludtryk, som outputrækkerne returneres fra.
If angivet, skal all kolonner i partitionBy komme fra den or en related tabel.
If udeladt: - orderBy skal angives eksplicit.– All orderBy andpartitionBy udtryk skal være fuldt kvalificerede kolonnenavne, and kommer fra en enkelt tabel.
– ALLSELECTED() af all kolonner i orderBy andpartitionBy som standard. |
axis |
(Valgfrit) En akse i visualiseringsfiguren.
and er kun tilgængelig i visuelle beregninger og erstatter relation . |
orderBy |
(Valgfrit) En ORDERBY()-delsætning, der indeholder de udtryk, der define, hvordan hver partition sorteres.
If udeladt: - relation skal angives eksplicit.
– Sorteres som standard efter hver kolonne i relation , der allerede er not angivet i partitionBy . |
blanks |
(Valgfrit) En optælling, der definerer, hvordan du håndterer blankvalues ved sortering.
Denne parameter er reserveret til fremtidig brug. I øjeblikket er den eneste understøttede value DEFAULT , hvor funktionsmåden for numeriske values er blankvalues sorteres mellem nul and negative values. Funktionsmåden for strenge er blankvalues sorteres før all strenge, herunder tomme strenge. |
partitionBy |
(Valgfrit) En PARTITIONBY() delsætning, der indeholder de kolonner, der define, hvordan relation partitioneres.
If udelades, behandles relation som en enkelt partition. |
matchBy |
(Valgfrit) En MATCHBY() delsætning, der indeholder de kolonner, der define, hvordan data skal matche and identificere den aktuelle række. |
reset |
(Valgfrit) Kun tilgængelig i visuelle beregninger. Angiverif beregningen nulstilles, and på hvilket niveau i den visuelle figurs kolonnehierarki. Accepterede values er: en feltreference til en kolonne i den aktuelle visualiseringsfigur, NONE (standard), LOWESTPARENT , HIGHESTPARENT or et heltal. Funktionsmåden afhænger af heltalet sign: - If nul or udeladt, nulstilles beregningen not. Svarer til NONE .
– If positiv, identificerer heltalet kolonnen med start fra den højeste, uafhængig af detaljering. HIGHESTPARENT svarer til 1.
– If negativ, identificerer heltalet kolonnen med start fra det laveste i forhold til den aktuelle detaljering. LOWESTPARENT svarer til -1. |
Returner value
All rækker fra window.
Bemærkninger
Except for kolonner, der tilføjes af DAX tabelfunktioner, skal hver kolonne i relation
, når matchBy
er not til stede, or hver kolonne i matchBy
andpartitionBy
, når matchBy
er til stede, have en tilsvarende ydre value for at hjælpe med at define den aktuelle række, der skal arbejdes på.
If
from_type
and
to_type
begge har valueABS, gælder følgende kun for de partitionBy
kolonner:
- If der er nøjagtigt én tilsvarende ydre kolonne, bruges dens value.
-
If der ikke er nogen tilsvarende ydre kolonne:
- WINDOW bestemmer firstall kolonner, der ikke har en tilsvarende ydre kolonne.
- For hver kombination af eksisterende values for disse kolonner i WINDOWoverordnede kontekst evalueres WINDOW, and de tilsvarende rækker returneres.
- WINDOW endelige output er en union af disse rækker.
- If der er mere end én tilsvarende ydre kolonne, returneres der en error.
If
all af relation
's kolonner blev tilføjet af DAX tabelfunktioner, returneres der en error.
If
matchBy
er til stede, forsøger WINDOW at bruge matchBy
andpartitionBy
kolonner til at identificere rækken.
If
matchBy
findes notand de kolonner, der er angivet i orderBy
andpartitionBy
, kan ikke entydigt identificere hver række i relation
, og derefter:
- WINDOW forsøger at find det mindste antal ekstra kolonner, der kræves for entydigt at identificere hver række.
-
If disse kolonner findes, føjer WINDOW automatisk disse nye kolonner til
orderBy
, and hver partition sorteres ved hjælp af dette nye sæt orderBy kolonner. - If sådanne kolonner ikke blev fundet, returneres der en error.
Der returneres en tom tabel if:
- Den tilsvarende ydre value af en
orderBy
orpartitionBy
kolonne findes not irelation
. - Hele window er uden for partitionen, or starten af window er efter slutningen.
If
WINDOW bruges i en beregnet kolonne, der er defineret i den samme tabel som relation
, andorderBy
udelades, returneres der en error.
If starten af window viser sig at være før den first række, angives den til den first række. På samme måde er if slutningen af window efter den last række i partitionen, så er den angivet til den last række.
reset
kun kan bruges i visuelle beregninger, kan and ikke bruges sammen med orderBy
orpartitionBy
.
If
reset
findes, kan axis
angives, men relation
kan ikke.
Eksempel 1 – measure
Følgende measure:
3-day Average Price =
AVERAGEX(
WINDOW(
-2,REL,0,REL,
SUMMARIZE(ALLSELECTED('Sales'), 'Date'[Date], 'Product'[Product]),
ORDERBY('Date'[Date]),
KEEP,
PARTITIONBY('Product'[Product])
),
CALCULATE(AVERAGE(Sales[Unit Price]))
)
Returnerer 3-dayaverage af enhedspriser for hver product. Bemærk, at 3-daywindow består af tre dage, hvor product har salg, not nødvendigvis tre på hinanden følgende calendar dage.
Eksempel 2 – measure
Følgende measure:
RunningSum =
SUMX (
WINDOW (
1, ABS, 0, REL,
ALLSELECTED (
'Date'[Fiscal Year],
'Date'[Month Number Of Year]
),
PARTITIONBY ( 'Date'[Fiscal Year] )
),
[Total Sales]
)
Returnerer den løbende sum for Samlet salg efter Month Antal Year, og genstarter for hver regnskabs Year:
Year | Month antal Year | Salgsbeløb | RunningSum |
---|---|---|---|
FY2018 | 0 | 1.327.675 USD | 1.327.675 USD |
FY2018 | 2 | 3.936.463 USD | 5.264.138 USD |
FY2018 | 3 | 700.873 USD | 5.965.011 USD |
FY2018 | 4 | 1.519.275 USD | 7.484.286 USD |
FY2018 | 5 | 2.960.378 USD | 10.444.664 USD |
FY2018 | 6 | 1.487.671 USD | 11.932.336 USD |
FY2018 | 7 | 1.423.357 USD | 13.355.693 USD |
FY2018 | 8 | 2.057.902 USD | 15.413.595 USD |
FY2018 | 9 | 2.523.948 USD | 17.937.543 USD |
FY2018 | 10 | 561.681 USD | 18.499.224 USD |
FY2018 | 11 | 4.764.920 USD | 23.264.145 USD |
FY2018 | 12 | 596.747 USD | 23.860.891 USD |
FY2019 | 0 | 1.847.692 USD | 1.847.692 USD |
FY2019 | 2 | 2.829.362 USD | 4.677.054 USD |
FY2019 | 3 | 2.092.434 USD | 6.769.488 USD |
FY2019 | 4 | 2.405.971 USD | 9.175.459 USD |
FY2019 | 5 | 3.459.444 USD | 12.634.903 USD |
FY2019 | 6 | 2.850.649 USD | 15.485.552 USD |
FY2019 | 7 | 2.939.691 USD | 18.425.243 USD |
FY2019 | 8 | 3.964.801 USD | 22.390.045 USD |
FY2019 | 9 | 3.287.606 USD | 25.677.650 USD |
FY2019 | 10 | 2.157.287 USD | 27.834.938 USD |
FY2019 | 11 | 3.611.092 USD | 31.446.030 USD |
FY2019 | 12 | 2.624.078 USD | 34.070.109 USD |
FY2020 | 0 | 3.235.187 USD | 3.235.187 USD |
FY2020 | 2 | 4.070.046 USD | 7.305.233 USD |
FY2020 | 3 | 4.429.833 USD | 11.735.066 USD |
FY2020 | 4 | 4.002.614 USD | 15.737.680 USD |
FY2020 | 5 | 5.265.797 USD | 21.003.477 USD |
FY2020 | 6 | 3.465.241 USD | 24.468.717 USD |
FY2020 | 7 | 3.513.064 USD | 27.981.781 USD |
FY2020 | 8 | 5.247.165 USD | 33.228.947 USD |
FY2020 | 9 | 5.104.088 USD | 38.333.035 USD |
FY2020 | 10 | 3.542.150 USD | 41.875.184 USD |
FY2020 | 11 | 5.151.897 USD | 47.027.081 USD |
FY2020 | 12 | 4.851.194 USD | 51.878.275 USD |
Eksempel 3 – visuel beregning
Følgende visualiseringsberegning DAX forespørgsel:
TotalSalesRunningSumByYear = SUMX(WINDOW(0, ABS, 0, REL, ROWS, HIGHESTPARENT), [SalesAmount])
Returnerer det samlede samlede salg efter month, beregnet sammen med hver year. De values 1 and -2 kan bruges i stedet for HIGHESTPARENT
med de samme resultater.
Skærmbilledet nedenfor viser den visuelle matrix and det visuelle beregningsudtryk:
Eksempel 4 – visuel beregning
Følgende visualiseringsberegning DAX forespørgsel:
TotalSalesRunningSumByQuarter = SUMX(WINDOW(0, ABS, 0, REL, , -1), [SalesAmount])
Returnerer det samlede samlede salg efter month, beregnet sammen med hver quarter.
Related indhold
INDEX MOVINGAVERAGE OFFSET ORDERBY PARTITIONBY RANGE RANK ROWNUMBER RUNNINGSUM