Window - Scriptfunctie
Window() voert berekeningen uit op meerdere rijen en produceert een waarde per rij.
U kunt de Window-functies gebruiken voor de volgende bewerkingen:
Een afzonderlijke getalwaarde in een rij vergelijken met het gemiddelde, maximum of minimum binnen de kolom.
De positie van een individuele waarde berekenen, hetzij binnen de kolom of in de gehele tabel.
De Window-functie verandert het aantal records in de tabel niet, maar kan wel vergelijke taken uitvoeren zoals aggregatie-, relationele en bereikfuncties.
De Window-functie moet een cache hebben binnen de LOAD-opdracht van de tabel waar u aan werkt om aan de tabel toe te voegen. Bijvoorbeeld:
Window ondersteunt algemene functies zoals afronding of basale numerieke bewerkingen. Bijvoorbeeld:
U kunt een sliding window voor de Window-functie definiëren. Dit stelt het aantal gebruikte rijen in wanneer de Window-functie op de huidige rij wordt toegepast. U kunt het venster bijvoorbeeld instellen om drie vorige rijen en de drie daarop volgende rijen te zijn:
Syntaxis:
Gegevenstype retourneren: een nieuw veld dat wordt toegevoegd aan de resulterende tabel die is gemaakt door de LOAD‑opdracht.
Argumenten:
| Argument | Beschrijving |
|---|---|
| input_expr | De invoeruitdrukking die wordt berekend en geretourneerd door de functie. Dit moet een uitdrukking zijn die is gebaseerd op een aggregatie, zoals Median(Salary). Bijvoorbeeld: Window(Median(Salary)) as MedianSalary De invoer kan ook een veldnaam zijn waarop geen aggregatie is toegepast. In dit geval behandelt Window dit alsof de Only()-functie is toegepast op dat veld. Bijvoorbeeld: Window(Salary,Department) as WSalary
U kunt eventueel partitionering definiëren met de invoeruitdrukking. Partitionering is hetzelfde als de groepering die wordt bereikt met de group by-clausule. Het enige verschil is dat het resultaat wordt toegevoegd als een nieuwe kolom in de invoertabel. Bij partionering wordt het aantal records van de invoertabel niet verminderd. Er kunnen meerdere partitievelden worden gedefinieerd. Voorbeeld:
LOAD
Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300) + AddMonths(OrderDate,-6) as MAX_Sales_City_Last_6_Mos, Window(Avg(Sales), City, 'ASC', OrderDate, City = 'Portland') + AddMonths(OrderDate,-6) as Avg_Sales_Portland_Last_6_Mos, Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300) + AddMonths(OrderDate,-12) as MAX_Sales_City_Last_12_Mos; LOAD City, Sales, OrderDate FROM [lib://:DataFiles/Sales Data.xlsx]FROM [lib://AttachedFiles/Sales Data.xlsx] (ooxml, embedded labels, table is [Sales Data]); |
| partition1, partition2 | Na input_expr kunt u een willekeurig aantal partities definiëren. Partities zijn velden die definiëren welke combinaties worden toegepast op de aggregaties. De aggregatie wordt bij elke partitie afzonderlijk toegepast. Bijvoorbeeld: Window(Avg(Salary), Unit, Department, Country) as AvgSalary In het bovenstaande voorbeeld zijn de partities Unit, Department en Country. Partities zijn niet verplicht, maar zijn vereist voor een juiste uitvoering van de window-functie op velden. |
| sort_type, [sort_expr]] | Geef desgewenst het sorteertype en de sorteeruitdrukking op. sort_type kan één of twee waarden bevatten:
Als u sort_type definieert, moet u een sorteeruitdrukking definiëren. Dit is een uitdrukking die de volgorde van de rijen in een partitie bepaalt. Bijvoorbeeld: Window(RecNo(), Department, 'ASC', Year) In het bovenstaande voorbeeld, worden de resultaten in de partitie in oplopende volgorde gesorteerd voor het veld Year. InformatieHet sorteertype en de sorteeruitdrukking zijn doorgaans alleen vereist bij de functies RecNo en WRank. |
| filter_expr | U kunt optioneel een filteruitdrukking toevoegen. Dit is een booleaanse uitdrukking die bepaalt of het record wel of niet in de berekening moet worden opgenomen. Deze parameter kan volledig worden weggelaten, wat ertoe leidt dat er geen filter is. Bijvoorbeeld: Window(avg(Salary), Department, 'ASC', Age, EmployeeID=3 Or EmployeeID=7) as wAvgSalary) as wAvgSalaryIfEmpIs3or7 |
| [start_expr,end_expr] | U kunt desgewenst het argument voor de functiontaliteit sliding window instellen. Een schuifvenster vereist twee argumenten:
Als u bijvoorbeeld 3 voorgaande rijen, de huidige rij en de volgende rij wilt toevoegen: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, -3, 1) Gebruik de functie Unbounded() om alle voorgaande of daaropvolgende rijen aan te geven. Als u bijvoorbeeld alle voorgaande rijen, de huidige rij en de volgende rij wilt opnemen: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, UNBOUNDED(), 1) Bijvoorbeeld al u de derde rij van de huidige rij alle daaropvolgende rijen wilt opnemen: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, 3, UNBOUNDED()) |
Voorbeeld: een veld met een aggregatie toevoegen
Voorbeeld: een veld met een aggregatie toevoegen, gefilterd op specifieke waarden
Voorbeeld: een veld met een schuifvenster toevoegen
Beperkingen
Window heeft de volgende beperkingen:
Window is een functie die veel resources gebruikt, vooral wat betreft geheugen.
Window wordt niet ondersteund in Qlik Sense Mobile.
Diagramuitdrukkingen bieden geen ondersteuning voor Window.
U kunt Window-functies niet nesten binnen andere Window-functies.
Window kan niet binnen een aggregatiefunctie worden gebruikt.
Window moet in staat zijn de volledige tabel te scannen.
WRank(), RecNo(), en RowNo() kunnen niet worden gebruikt met Window als de sliding window wordt gebruikt.