GROUPBY

Материал из GB wiki
Перейти к: навигация, поиск

Позволяет группировать датасет по ключевым полям, суммируя при этом значения полей, которые не участвовали в группировке.

Синтаксис

GROUPBY(Имя датасета, Поля для группировки, Поля для суммирования, Имя датасета результата)

Аргументы

Имя датасета
строка, имя датасета, поля которого подлежат группировке.
Поля для группировки
Строка, список ключевых полей для группировки через ";". Также можно использовать массив строк без ключей.
Поля для суммирования
Строка, список полей для суммирования через ";". После каждого поля может быть указана функция через знак "=". Также можно использовать массив, где ключи – имена полей, значения – функции.

Список функций:

  • SUM – сумма значений;
  • MIN – минимальное значение;
  • STRMIN – минимальное значение (сравнение числовых значений как строк);
  • MAX – максимальное значение;
  • STRMAX – максимальное значение (сравнение числовых значений как строк);
  • LIST – список значений (через ";");
  • STRSUM – все значения в общей строке без разделителей.
Примечание. Для пар функций MIN–STRMIN и MAX–STRMAX следующие различия в сравнении числовых значений:
  • 9 < 10, если сравнивать как числа (MIN, MAX);
  • "9" > "10", если сравнивать как строки, т.к. при посимвольном сравнении "9">"1" (STRMIN, STRMAX).
Имя датасета результата
строка, имя датасета. Необязательный параметр, если задан, то результат группировки будет помещён в этот датасет (иначе – результат группировки помещается в исходный датасет).

Тип результата

Нет

Примеры

GroupBy('foDS', 'Articul', 'Quantity')
GroupBy('pds', 'Node;Name', 'Id=SUM;Name=LIST')
GroupBy('pds', ['Node','Name'], ['Id':'SUM','Name':'LIST'])