Window — функция скрипта
Window() выполняет вычисления по нескольким строкам раздела («окно») в полной таблице и выдает отдельное значение для каждой строки.
Функции Window позволяют выполнять следующие операции:
-
Сравнение отдельного числового значения в строке со средним, максимальным или минимальным значением внутри окна таблицы.
-
Расчет ранга отдельного значения в окне или во всей таблице.
Функция Window не изменяет количество записей в таблице, но все же может выполнять задачи, подобные функциям агрегирования, реляционных функций и функций над выборкой.
Функция Window должна быть включена в оператор LOAD обрабатываемой таблицы или ссылаться на таблицу, например, с помощью Resident LOAD. Например, см. Пример. Добавление поля, содержащего агрегирование.
Имя можно опустить, но в этом случае именем поля будет все выражение функции Window. Например, AvgDepSalary в примере ниже:
Рекомендуется дать функции Window имя поля.
Window поддерживает общие функции, такие как округление или базовые операции с числами. Пример:
Функция Window сканирует всю таблицу. С точки зрения потребления памяти, стоимость такого сканирования пропорциональна количеству полей в таблице. Таблица с несколькими полями, помимо тех, которые обрабатываются функцией Window, всегда предпочтительнее таблицы с большим количеством полей.
Как правило, функция Window потребляет в 2-4 раза больше памяти и занимает в 2-4 раза больше времени на перезагрузку по сравнению с аналогичной операцией скрипта, содержащей такое же агрегирование, оператор Where, оператор Group by (разбиение) и оператор Order by (сортировка).
Синтаксис:
Тип возвращаемых данных: одно значение на строку, которое может быть объединено с другим выражением или использовано в нем или добавлено непосредственно в результирующую таблицу, созданную с помощью оператора LOAD.
Аргументы:
Аргумент | Описание |
---|---|
main_expr | Основное входное выражение, вычисленное и возвращенное функцией. Это должно быть любое выражение на основе агрегирования, например Median(Salary). Пример: Window(Median(Salary)) as MedianSalary В качестве выражения может выступать имя поля, к которому не применено агрегирование. В этом случае Window обрабатывает его, как если бы к нему была применена функция Only(). Пример: Window(Salary) as WSalary Не разрешаются выражения, включающие вложенные функции агрегирования или оконные функции, такие как Window(Sum(Avg(Salary))) или Window(Sum(Window(Salary))). |
partition1, partition2 | После main_expr можно определить любое количество разделов. Разделы — это поля, которые определяют, какие с какими комбинациями должны применяться агрегирования. Пример: Window(Avg(Salary), Department) as AvgDepSalary Здесь рассчитывается средняя зарплата по каждому из отделов. Если указано несколько параметров разбиения, агрегирование будет применено к каждой строке с уникальной комбинацией полей разбиения. Пример: Window(Avg(Salary), Department, Country) as AvgDepSalaryPerCountry Здесь рассчитывается средняя зарплата по каждому из отделов во всех странах. Дублирующиеся отделы в разных странах, например, отдел маркетинга в Швеции и отдел маркетинга в Канаде, будут включаться в разные разбиения. Разбиение аналогично группировке, достигаемой с помощью оператора group by. Разбиение не уменьшает количество записей по сравнению с входной таблицей. |
sort_type, [sort_expr] | При желании задайте тип сортировки и выражение сортировки. Это определяет порядок, в котором выполняется функция агрегирования. sort_type – это строка с константой, которая может иметь одно из трех значений:
Если определено в sort_type задано ASC или DESC, также необходимо определить выражение сортировки. При использовании sort_type NONE выражение сортировки не требуется. Это выражение сортировки, которое определяет порядок строк в разделе. Пример: Window(RecNo(), Department, 'ASC', Year) В приведенном выше примере, функция агрегирования в разделе выполняется по возрастанию значения в поле Year. Параметры сортировки также влияют на порядок, в котором скользящее окно обрабатывает таблицу. Для ознакомления с примером см. раздел Пример. Добавление поля с сортируемым скользящим окном. |
filter_expr | При желании можно добавить выражение фильтра. Это логическое выражение, которое определяет, следует включать запись в расчет или нет. Если используется filter_expr, необходимо включить тип сортировки. Если тип сортировки не определен, аргумент может быть интерпретирован как параметр разделения, а не как выражение сортировки. Параметр filter_expr может быть опущен полностью или в него может быть включено истинное значение. В обоих случаях фильтры не используются, поэтому ни один ряд не исключен. Пример: Window(avg(Salary), Department, 'ASC', Age, Country='US' Or Country='Canada') as AvgDepSalaryInUsOrCanada Приведенный выше оператор Window фильтрует все строки, в которых поле Country не является US или Canada и исключает эти строки из агрегирования. Для строк, которые были отфильтрованы, все равно будут получены результаты, но, как и остальные выходные строки, они будут содержать только агрегированные результаты из строк, не исключенных фильтром. |
start_expr,end_expr | При желании можно задать аргументы для функции скользящего окна. Это еще больше ограничивает число строк, которые можно объединить. Каждая выходная строка будет включать только (агрегированные) результаты из строк, предшествующих текущей строке и следующих за ней. Скользящее окно требует два аргумента:start_expr,end_expr. Если эти аргументы указаны, то тип сортировки является обязательным. В противном случае аргументы могут быть интерпретированы как параметр разбиения вместо скользящего окна. Параметр start_expr,end_expr включает в себя:
Например, если требуется включить три предшествующие строки, текущую строку и следующую строку: Window(concat(Text(Salary),'-'), Department, 'NONE', 1, -3, 1) as WSlidingSalaryDepartment Чтобы указать все предыдущие или все последующие строки, можно использовать функцию Unbounded(). Например, если требуется включить все предшествующие строки, текущую строку и следующую за ней строку: Window(concat(Text(Salary),'-'), Department, 'NONE', 1, UNBOUNDED(), 1) as WSlidingSalaryDepartment Например, чтобы включить третью строку от текущей и все последующие строки: Window(concat(Text(Salary),'-'), Department, 'NONE', 1, 3, UNBOUNDED()) as WSlidingSalaryDepartment В приведенных выше примерах тип сортировки NONE указан для того, чтобы скрипт мог отличить аргументы разбиения от параметров, которые идут после типа сортировки. |
Пример. Добавление поля, содержащего агрегирование
Пример. Добавление поля, содержащего агрегирование с фильтрацией по конкретным значениям
Пример. Добавление поля со скользящим окном
Ограничения
Window имеет следующие ограничения:
Функция Window интенсивно потребляет ресурсы, особенно память.
Window не поддерживается в Qlik Sense Mobile.
Выражения диаграммы не поддерживают Window.
Нельзя вкладывать функции Window в другие функции Window.
Window нельзя использовать внутри функции агрегирования.
Window нельзя использовать в операторе загрузки вместе с group by.
Window должно иметь возможность сканировать всю таблицу.
WRank(), RecNo() и RowNo() нельзя использовать вместе с Window при использовании функции скользящего окна.
При использовании функции скользящего окна время вычислений увеличивается в зависимости от размера окна. Как правило, следует избегать больших таблиц с окнами большого размера.