VINDUE
Gælder for: Beregning af målingsvisualisering for beregnet kolonne i beregnet tabel
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 |
---|---|
fra | Angiver, hvor vinduet starter. Det kan være et hvilket som helst DAX-udtryk, der returnerer en skalarværdi. Funktionsmåden afhænger af parameteren <from_type> : - Hvis <from_type> er REL, er det antal rækker, der skal gå tilbage (negativ værdi) eller fremad (positiv værdi) fra den aktuelle række for at hente den første række i vinduet. - Hvis <from_type> er ABS, og <fra> er positiv, så er det placeringen af starten af vinduet fra begyndelsen af partitionen. Indeksering er 1-baseret. 1 betyder f.eks., at vinduet starter fra starten af partitionen. Hvis <fra> er negativ, er det placeringen af starten af vinduet fra slutningen af partitionen. -1 betyder den sidste række i partitionen. |
from_type | Ændrer funktionsmåden for parameteren <from> . Mulige værdier er ABS (absolut) og REL (relativ). Standard er REL. |
til | Det samme som <fra>, men angiver slutningen af vinduet. Den sidste række er inkluderet i vinduet. |
to_type | Det samme som <from_type>, men ændrer funktionsmåden for <til>. |
forhold | (Valgfrit) Et tabeludtryk, som outputrækkerne returneres fra. Hvis det er angivet, skal alle kolonner i <partitionBy> komme fra den eller en relateret tabel. Hvis det udelades: - <orderBy> skal angives eksplicit. – Alle <orderBy> - og <partitionBy-udtryk> skal være fuldt kvalificerede kolonnenavne og komme fra en enkelt tabel. – Som standard til ALLSELECTED() for alle kolonner i <orderBy> og <partitionBy>. |
akse | (Valgfrit) En akse i visualiseringsfiguren. Kun tilgængelig i visuelle beregninger og erstatter <relationen>. |
orderBy | (Valgfrit) En ORDERBY()-delsætning, der indeholder de udtryk, der definerer, hvordan hver partition sorteres. Hvis det udelades: - <relationen> skal angives eksplicit. – Som standard sorteres efter hver kolonne i <relation> , der ikke allerede er angivet i <partitionBy>. |
Tomme | (Valgfrit) En optælling, der definerer, hvordan tomme værdier skal håndteres ved sortering. Denne parameter er reserveret til fremtidig brug. I øjeblikket er den eneste understøttede værdi DEFAULT, hvor funktionsmåden for numeriske værdier er tomme værdier sorteres mellem nul og negative værdier. Funktionsmåden for strenge er tomme værdier sorteres før alle strenge, herunder tomme strenge. |
partitionBy | (Valgfrit) En PARTITIONBY()-delsætning, der indeholder de kolonner, der definerer, hvordan <relationen> partitioneres. Hvis den udelades, <behandles relationen> som en enkelt partition. |
matchBy | (Valgfrit) En MATCHBY()-delsætning, der indeholder de kolonner, der definerer, hvordan dataene skal matche og identificere den aktuelle række. |
Nulstille | (Valgfrit) Kun tilgængelig i visuelle beregninger. Angiver, om beregningen nulstilles, og på hvilket niveau i den visuelle figurs kolonnehierarki. Accepterede værdier er: NONE, LOWESTPARENT, HIGHESTPARENT eller et heltal. Funktionsmåden afhænger af heltalstegnet: - Hvis nul eller udeladt, nulstilles beregningen ikke. Svarer til NONE. – Hvis den er positiv, identificerer heltalet kolonnen med start fra den højeste, uafhængig af kornet. HIGHESTPARENT svarer til 1. – Hvis det er negativt, identificerer heltalet kolonnen med start fra det laveste i forhold til den aktuelle detaljering. LOWESTPARENT svarer til -1. |
Returværdi
Alle rækker fra vinduet.
Bemærkninger
Med undtagelse af kolonner, der tilføjes af DAX-tabelfunktioner, skal hver kolonne i <relationen>, når <matchBy> ikke findes, eller hver kolonne i <matchBy> og <partitionBy>, når <matchBy> er til stede, have en tilsvarende ydre værdi for at hjælpe med at definere den aktuelle række, der skal arbejdes på. Hvis from_type og to_type> begge har værdien ABS, gælder følgende kun for partitionBy-kolonnerne:> <<> <
- Hvis der er nøjagtigt én tilsvarende ydre kolonne, bruges dens værdi.
- Hvis der ikke er en tilsvarende ydre kolonne:
- WINDOW bestemmer først alle kolonner, der ikke har en tilsvarende ydre kolonne.
- For hver kombination af eksisterende værdier for disse kolonner i WINDOW's overordnede kontekst evalueres WINDOW, og de tilsvarende rækker returneres.
- Det endelige vinduesoutput er en forening af disse rækker.
- Hvis der er mere end én tilsvarende ydre kolonne, returneres der en fejl.
Hvis alle <relationens> kolonner blev tilføjet af DAX-tabelfunktioner, returneres der en fejl.
Hvis <matchBy> er til stede, forsøger WINDOW at bruge <matchBy> - og <partitionBy-kolonnerne> til at identificere rækken.
Hvis <matchBy> ikke findes, og de kolonner, der er angivet i <orderBy> og <partitionBy> , ikke entydigt kan identificere hver række i <relationen>, så:
- WINDOW forsøger at finde det mindste antal ekstra kolonner, der kræves for entydigt at identificere hver række.
- Hvis sådanne kolonner kan findes, føjer WINDOW automatisk disse nye kolonner til <orderBy>, og hver partition sorteres ved hjælp af dette nye sæt orderBy-kolonner.
- Hvis sådanne kolonner ikke blev fundet, returneres der en fejl.
Der returneres en tom tabel, hvis:
- Den tilsvarende ydre værdi af kolonnen <orderBy> eller <partitionBy> findes ikke i <relationen>.
- Hele vinduet er uden for partitionen, eller starten af vinduet er efter dets afslutning.
Hvis WINDOW bruges i en beregnet kolonne, der er defineret i den samme tabel som <relationen>, og <orderBy> udelades, returneres der en fejl.
Hvis starten af vinduet viser sig at være før den første række, angives den til den første række. Hvis slutningen af vinduet er efter den sidste række i partitionen, er den på samme måde angivet til den sidste række.
<nulstilling> kan kun bruges i visuelle beregninger og kan ikke bruges i kombination med <orderBy> eller <partitionBy>. Hvis <nulstilling> er til stede, kan aksen> angives, <men <relationen> kan ikke.
Eksempel 1 – måling
Følgende måling:
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 det 3-dages gennemsnit af enhedspriser for hvert produkt. Bemærk, at 3-dages vinduet består af tre dage, hvor produktet har salg, ikke nødvendigvis tre kalenderdage i træk.
Eksempel 2 – måling
Følgende måling:
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 månedsnummer på år og genstarter for hvert regnskabsår:
Year | Månedsnummer på år | 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 DAX-forespørgsel til visuel beregning:
TotalSalesRunningSumByYear = SUMX(WINDOW(0, ABS, 0, REL, ROWS, HIGHESTPARENT), [SalesAmount])
Returnerer det akkumulerede samlede salg pr. måned beregnet sammen med hvert år. Værdierne 1 og -2 kan bruges i stedet for HIGHESTPARENT med de samme resultater.
Skærmbilledet nedenfor viser den visuelle matrix og det visuelle beregningsudtryk:
Eksempel 4 – visuel beregning
Følgende DAX-forespørgsel til visuel beregning:
TotalSalesRunningSumByQuarter = SUMX(WINDOW(0, ABS, 0, REL, , -1), [SalesAmount])
Returnerer det akkumulerede samlede salg pr. måned beregnet for hvert kvartal.
Relateret indhold
INDEKS
FLYTNING AF GENNEMSNIT
FORSKYDNING
ORDERBY
PARTITIONBY
INTERVAL
RANG
RUNNINGSUM FOR RÆKKENUMMER