OKNO

Platí pro:Calculated columnCalculated tableMeasureVisual calculation

Vrátí více řádků, které jsou umístěny v daném intervalu.

Syntaxe

WINDOW ( from[, from_type], to[, to_type][, <relation> or <axis>][, <orderBy>][, <blanks>][, <partitionBy>][, <matchBy>][, <reset>] )

Parametry

Pojem definice
from Určuje, kde se okno spouští. Může to být libovolný výraz DAX, který vrací skalární hodnotu.
Chování závisí na parametru <from_type> :
– Pokud <je from_type> REL, počet řádků, které se mají vrátit (záporná hodnota) nebo předat dál (kladná hodnota) z aktuálního řádku, aby se první řádek v okně získal.
- Pokud <je from_type> ABS a <z> pozitivní, pak je to pozice začátku okna od začátku oddílu. Indexování je založené na 1. Například 1 znamená, že okno začíná od začátku oddílu. Pokud <je záporná> , pak se jedná o pozici začátku okna od konce oddílu. -1 znamená poslední řádek v oddílu.
from_type Upraví chování parametru<.> Možné hodnoty jsou ABS (absolutní) a REL (relativní). Výchozí hodnota je REL.
na Stejné jako <od>, ale označuje konec okna. Poslední řádek je součástí okna.
to_type Stejné jako <from_type>, ale upraví chování <>na.
Vztah (Volitelné) Výraz tabulky, ze kterého se vrátí výstupní řádky.
Pokud je zadáno, musí všechny sloupce v <partitionBy> pocházet z ní nebo související tabulka.
Pokud tento parametr vynecháte:
– <orderBy> musí být explicitně zadáno.
– Všechny <výrazy orderBy> a <partitionBy> musí být plně kvalifikované názvy sloupců a pocházejí z jedné tabulky.
– Výchozí hodnota je ALLSELECTED() všech sloupců v <pořadíBy> a <partitionBy>.
osa (Volitelné) Osa ve vizuálním obrazci. K dispozici pouze ve vizuálních výpočtech <a nahrazuje relaci>.
Orderby (Volitelné) Klauzule ORDERBY() obsahující výrazy definující způsob řazení jednotlivých oddílů.
Pokud tento parametr vynecháte,
<musí být explicitně zadán vztah>.
– Výchozí nastavení řazení podle každého sloupce ve <vztahu> , který ještě není zadán v <partitionBy>.
Mezery (Volitelné) Výčet, který definuje, jak zpracovat prázdné hodnoty při řazení.
Tento parametr je vyhrazen pro budoucí použití.
V současné době je jedinou podporovanou hodnotou VÝCHOZÍ, kde chování číselných hodnot je prázdné hodnoty seřazené mezi nulou a zápornými hodnotami. Chování řetězců je prázdné hodnoty seřazené před všemi řetězci, včetně prázdných řetězců.
partitionBy (Volitelné) Klauzule PARTITIONBY() obsahující sloupce definující způsob <rozdělení relace> . Pokud tento parametr vynecháte, <považuje se relace> za jeden oddíl.
matchBy (Volitelné) Klauzule POZVYHLEDAT() obsahující sloupce, které definují, jak se shodují s daty, a identifikují aktuální řádek.
resetování (Volitelné) K dispozici pouze ve vizuálních výpočtech. Určuje, jestli se výpočet resetuje a na jaké úrovni hierarchie sloupců obrazce vizuálu. Přijaté hodnoty jsou: NONE, LOWESTPARENT, HIGHESTPARENT nebo celé číslo. Chování závisí na celočíselném znaménku:
– Pokud je nula nebo vynechána, výpočet se neobnoví. Ekvivalent funkce NONE.
- Pokud je kladné, celé číslo identifikuje sloupec začínající od nejvyššího, nezávisle na agregačním intervalu. FUNKCE HIGHESTPARENT je ekvivalentní hodnotě 1.
- Pokud je záporné, celé číslo identifikuje sloupec počínaje nejnižší hodnotou vzhledem k aktuálnímu agregačnímu intervalu. NEJNIŽŠÍPARENT je ekvivalentní hodnotě -1.

Vrácená hodnota

Všechny řádky z okna.

Poznámky

S výjimkou sloupců přidaných funkcemi tabulky DAX musí mít každý sloupec v <relaci, pokud <matchBy> není k dispozici, nebo každý sloupec v <matchBy> a <partitionBy>, pokud <je k dispozici matchBy>, musí mít odpovídající vnější hodnotu, aby bylo možné definovat aktuální řádek, ve kterém> se má pracovat. Pokud from_type i to_type> oba mají hodnotu ABS, platí následující informace pouze pro <sloupce partitionBy>:<><

  • Pokud je právě jeden odpovídající vnější sloupec, použije se jeho hodnota.
  • Pokud neexistuje odpovídající vnější sloupec:
    • OKNO nejprve určí všechny sloupce, které nemají odpovídající vnější sloupec.
    • Pro každou kombinaci existujících hodnot pro tyto sloupce v nadřazené kontextu WINDOW se vyhodnotí funkce WINDOW a vrátí se odpovídající řádky.
    • Konečný výstup okna je sjednocením těchto řádků.
  • Pokud existuje více než jeden odpovídající vnější sloupec, vrátí se chyba.

Pokud funkce tabulky DAX přidaly všechny sloupce relačních <>relací, vrátí se chyba.

Pokud <je k dispozici shodaBy> , okno se pokusí použít <sloupce matchBy> a <partitionBy> k identifikaci řádku.
Pokud <matchBy> není k dispozici a sloupce zadané v rámci <orderBy> a <partitionBy> nemohou jednoznačně identifikovat každý řádek v <relaci>, pak:

  • OKNO se pokusí najít nejmenší počet dalších sloupců potřebných k jednoznačné identifikaci každého řádku.
  • Pokud tyto sloupce najdete, window tyto nové sloupce automaticky připojí k <orderBy> a každý oddíl se seřadí pomocí této nové sady sloupců orderBy.
  • Pokud tyto sloupce nelze najít, vrátí se chyba.

Prázdná tabulka se vrátí, pokud:

  • Odpovídající vnější hodnota <sloupce orderBy> nebo <partitionBy> neexistuje v rámci <relace>.
  • Celé okno je mimo oddíl nebo začátek okna je za koncem okna.

Pokud se funkce WINDOW používá v počítaném sloupci definovaném ve stejné tabulce jako <relace> a <funkce orderBy> je vynechána, vrátí se chyba.

Pokud se začátek okna zobrazí před prvním řádkem, nastaví se na první řádek. Podobně platí, že pokud je konec okna za posledním řádkem oddílu, nastaví se na poslední řádek.

<Resetování> lze použít pouze ve vizuálních výpočtech a nelze ho použít v kombinaci s <orderBy> nebo <partitionBy>. Pokud <je k dispozici resetování>, je možné zadat osu>, <ale <relační nemůže>.

Příklad 1 – míra

Následující míra:

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]))
)

Vrátí 3denní průměr jednotkových cen pro každý produkt. Všimněte si, že třídenní okno se skládá ze tří dnů, ve kterých má produkt prodej, ne nutně tři po sobě jdoucí kalendářní dny.

Příklad 2 – míra

Následující míra:

RunningSum =
SUMX (
    WINDOW (
        1, ABS, 0, REL,
        ALLSELECTED (
            'Date'[Fiscal Year],
            'Date'[Month Number Of Year]
        ),
        PARTITIONBY ( 'Date'[Fiscal Year] )
    ),
    [Total Sales]
)

Vrátí průběžný součet celkového prodeje podle počtu měsíců roku a restartuje se pro každý fiskální rok:

Year (Rok) Month Number Of Year Částka prodeje RunningSum
FY2018 0 1 327 675 Kč 1 327 675 Kč
FY2018 2 3 936 463 Kč 5 264 138 Kč
FY2018 3 700 873 Kč 5 965 011 Kč
FY2018 4 1 519 275 Kč 7 484 286 Kč
FY2018 5 2 960 378 Kč 10 444 664 Kč
FY2018 6 1 487 671 Kč 11 932 336 Kč
FY2018 7 1 423 357 Kč 13 355 693 Kč
FY2018 8 2 057 902 Kč 15 413 595 Kč
FY2018 9 2 523 948 Kč 17 937 543 Kč
FY2018 10 561 681 Kč 18 499 224 Kč
FY2018 11 4 764 920 Kč 23 264 145 Kč
FY2018 12 596 747 Kč 23 860 891 Kč
FY2019 0 1 847 692 Kč 1 847 692 Kč
FY2019 2 2 829 362 Kč 4 677 054 Kč
FY2019 3 2 092 434 Kč 6 769 488 Kč
FY2019 4 2 405 971 Kč 9 175 459 Kč
FY2019 5 3 459 444 Kč 12 634 903 Kč
FY2019 6 2 850 649 Kč 15 485 552 Kč
FY2019 7 2 939 691 Kč 18 425 243 Kč
FY2019 8 3 964 801 Kč 22 390 045 Kč
FY2019 9 3 287 606 Kč 25 677 650 Kč
FY2019 10 2 157 287 Kč 27 834 938 Kč
FY2019 11 3 611 092 Kč 31 446 030 Kč
FY2019 12 2 624 078 Kč 34 070 109 Kč
FY2020 0 3 235 187 Kč 3 235 187 Kč
FY2020 2 4 070 046 Kč 7 305 233 Kč
FY2020 3 4 429 833 Kč 11 735 066 Kč
FY2020 4 4 002 614 Kč 15 737 680 Kč
FY2020 5 5 265 797 Kč 21 003 477 Kč
FY2020 6 3 465 241 Kč 24 468 717 Kč
FY2020 7 3 513 064 Kč 27 981 781 Kč
FY2020 8 5 247 165 Kč 33 228 947 Kč
FY2020 9 5 104 088 Kč 38 333 035 Kč
FY2020 10 3 542 150 Kč 41 875 184 Kč
FY2020 11 5 151 897 Kč 47 027 081 Kč
FY2020 12 4 851 194 Kč 51 878 275 Kč

Příklad 3 – výpočet vizuálu

Následující dotaz jazyka DAX pro výpočet vizuálu:

TotalSalesRunningSumByYear = SUMX(WINDOW(0, ABS, 0, REL, ROWS, HIGHESTPARENT), [SalesAmount])

Vrátí kumulativní celkový prodej podle měsíce vypočítaný po jednotlivých letech. Hodnoty 1 a -2 lze použít místo funkce HIGHESTPARENT se stejnými výsledky.

Následující snímek obrazovky ukazuje vizuální matici a výraz výpočtu vizuálu:

Výpočet vizuálu DAX

Příklad 4 – výpočet vizuálu

Následující dotaz jazyka DAX pro výpočet vizuálu:

TotalSalesRunningSumByQuarter = SUMX(WINDOW(0, ABS, 0, REL, , -1), [SalesAmount])

Vrátí kumulativní celkový prodej podle měsíce vypočítaný po jednotlivých čtvrtletích.

INDEX
PŘESOUVACÍ AVERAGE
POSUN
ORDERBY
PARTITIONBY
ROZSAH
HODNOST
ROWNUMBERRUNNINGSUM