Window - Funzione script
Window() esegue calcoli da più righe, producendo un valore per ciascuna riga separatamente.
Le funzioni Window possono essere utilizzate per eseguire operazioni quali:
Confronto tra un singolo valore numerico di una riga e la media, il massimo o il minimo della colonna.
Calcolare la classificazione di un valore individuale, all'interno della colonna o dell'intera tabella.
La funzione Window non cambia il numero di record nella tabella, ma può comunque eseguire attività simili a funzioni di aggregazione, relazionali e di scala.
La funzione Window deve avere una cache all'interno dell'istruzione LOAD della tabella con cui si sta lavorando per effettuare aggiunte alla tabella. Ad esempio:
Window supporta funzioni generali, come l'arrotondamento o operazioni numeriche di base. Ad esempio:
È possibile definire una finestra di scorrimento per la funzione Window. Ciò imposta il numero di righe utilizzate quando si applica la funzione Window sulla riga corrente. Ad esempio, è possibile impostare la finestra in modo tale che includa le 3 righe precedenti e le 3 righe successive.
Sintassi:
Tipo di dati restituiti: un nuovo campo aggiunto alla tabella risultante creata dall'istruzione LOAD.
Argomenti:
| Argomento | Descrizione |
|---|---|
| input_expr | L'espressione di ingresso calcolata e restituita dalla funzione. Deve essere un'espressione basata su un'aggregazione, come ad esempio Median(Salary). Ad esempio: Window(Median(Salary)) as MedianSalary L'input può anche essere il nome di un campo senza alcuna aggregazione. In questo caso, Window lo tratta come la funzione Only() applicata a tale campo. Ad esempio: Window(Salary,Department) as WSalary
Opzionalmente, è possibile definire il partizionamento con l'espressione di input. Il partizionamento è uguale al raggruppamento ottenuto con la clausola group by, con la differenza che il risultato viene aggiunto come nuova colonna alla tabella di input. Il partizionamento non riduce il numero di record della tabella di input. È possibile definire più campi di partizione. Esempio:
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 | Dopo input_expr, è possibile definire un numero qualsiasi di partizioni. Le partizioni sono campi che definiscono le combinazioni con cui applicare le aggregazioni. L'aggregazione viene applicata separatamente a ciascuna partizione. Ad esempio: Window(Avg(Salary), Unit, Department, Country) as AvgSalary In questo caso, le partizioni sono Unit, Department e Country. Le partizioni non sono obbligatorie, ma sono necessarie per una corretta finestratura dei campi. |
| sort_type, [sort_expr]] | Opzionalmente, specificare il tipo di ordinamento e l'espressione di ordinamento. sort_type può avere uno dei due valori seguenti:
Se si definisce sort_type, è necessario definire anche un'espressione di ordinamento. È un'espressione che decide l'ordine delle righe all'interno di una partizione. Ad esempio: Window(RecNo(), Department, 'ASC', Year) Nell'esempio precedente, i risultati all'interno della partizione sono ordinati in modo crescente in base al campo Year. Nota informaticaIl tipo di ordinamento e l'espressione di ordinamento sono necessari solo per le funzioni RecNo e WRank. |
| filter_expr | Aggiungere facoltativamente un'espressione di filtro. È un'espressione booleana che decide se il record deve essere incluso o meno nel calcolo. Questo parametro può essere omesso completamente e il risultato dovrebbe essere che non c'è alcun filtro. Ad esempio: Window(avg(Salary), Department, 'ASC', Age, EmployeeID=3 Or EmployeeID=7) as wAvgSalary) as wAvgSalaryIfEmpIs3or7 |
| [start_expr,end_expr] | Opzionalmente, impostare l'argomento per la funzionalità di finestra di scorrimento. Una finestra scorrevole richiede due argomenti:
Ad esempio, se si vuole includere le 3 righe precedenti, la riga corrente e la riga successiva: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, -3, 1) Per indicare tutte le righe precedenti o tutte le righe successive, è possibile utilizzare la funzione Unbounded(). Ad esempio, per includere tutte le righe precedenti, la riga corrente e la riga successiva: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, UNBOUNDED(), 1) Ad esempio, per includere la terza riga dalla riga corrente e tutte le righe successive: Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, 3, UNBOUNDED()) |
Esempio - Aggiunta di un campo contenente un'aggregazione
Esempio: aggiunta di un campo contenente un'aggregazione con un filtro per valori specifici
Esempio - Aggiunta di un campo con una finestra scorrevole
Limitazioni
Window ha le seguenti limitazioni:
Window è una funzione che ha un forte impatto sulle risorse, soprattutto in termini di consumo di memoria.
Window non è supportato in Qlik Sense Mobile.
Le espressioni del grafico non supportano Window.
Non è possibile nidificare le funzioni Window all'interno di altre funzioni Window.
Non è possibile utilizzare Window all'interno di una funzione di aggregazione.
Window deve essere in grado di analizzare l'intera tabella.
Non è possibile utilizzare WRank(), RecNo() e RowNo() con Window quando si utilizza la funzione finestra di scorrimento.