Перейти к основному содержимому Перейти к дополнительному содержимому

Window — функция скрипта

Window() выполняет вычисления по нескольким строкам раздела («окно») в полной таблице и выдает отдельное значение для каждой строки.

Функции Window позволяют выполнять следующие операции:

  • Сравнение отдельного числового значения в строке со средним, максимальным или минимальным значением внутри окна таблицы.

  • Расчет ранга отдельного значения в окне или во всей таблице.

Функция Window не изменяет количество записей в таблице, но все же может выполнять задачи, подобные функциям агрегирования, реляционных функций и функций над выборкой.

Функция Window должна быть включена в оператор LOAD обрабатываемой таблицы или ссылаться на таблицу, например, с помощью Resident LOAD. Например, см. Пример. Добавление поля, содержащего агрегирование.

Имя можно опустить, но в этом случае именем поля будет все выражение функции Window. Например, AvgDepSalary в примере ниже:

[AvgSalary]: Load *, Window(avg(Salary), Department) as AvgDepSalary Resident Employees;
Примечание к информации

Рекомендуется дать функции Window имя поля.

Window поддерживает общие функции, такие как округление или базовые операции с числами. Пример:

Load *, Round(Window(Sum(Salary),Department)) as SumDepSalary
Load *, Window(Sum(Salary),Department) + 5 as SumDepSalary
Примечание к информации

Функция Window сканирует всю таблицу. С точки зрения потребления памяти, стоимость такого сканирования пропорциональна количеству полей в таблице. Таблица с несколькими полями, помимо тех, которые обрабатываются функцией Window, всегда предпочтительнее таблицы с большим количеством полей.

Как правило, функция Window потребляет в 2-4 раза больше памяти и занимает в 2-4 раза больше времени на перезагрузку по сравнению с аналогичной операцией скрипта, содержащей такое же агрегирование, оператор Where, оператор Group by (разбиение) и оператор Order by (сортировка).

Синтаксис:  

Window (main_expr, [partition1, partition2, ...], [sort_type, [sort_expr],[filter_expr], [start_expr, end_expr]])

Тип возвращаемых данных: одно значение на строку, которое может быть объединено с другим выражением или использовано в нем или добавлено непосредственно в результирующую таблицу, созданную с помощью оператора 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 – это строка с константой, которая может иметь одно из трех значений:

  • ASC: сортировка по возрастанию.

  • DESC: сортировка по убыванию.

  • NONE

Если определено в 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 при использовании функции скользящего окна.

  • При использовании функции скользящего окна время вычислений увеличивается в зависимости от размера окна. Как правило, следует избегать больших таблиц с окнами большого размера.

Помогла ли вам эта страница?

Если вы обнаружили какую-либо проблему на этой странице или с ее содержанием — будь то опечатка, пропущенный шаг или техническая ошибка, сообщите нам об этом!