[Alimir_BootModal_Login]

Язык запросов 1С 8.3 для начинающих программистов: группировка

Автор уроков и преподаватель школы: Владимир Милькин

Группировка в запросах

Давайте запросим из таблицы Справочник.Еда следующие реквизиты: Наименование, Цвет и Калорийность:

ВЫБРАТЬ
	Наименование,
	Цвет,
	Калорийность
ИЗ
	Справочник.Еда

01

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

Алгоритм для жёлтого цвета будет такой:

  1. Находим все строчки у которых в поле Цвет стоит Жёлтый.
  2. Это будут строчки №1, 6, 8 и 9.
  3. Суммируем поле Калорийность для каждой из этих строк: 89 + 31 + 340 + 536
  4. Получаем, что для жёлтого цвета суммарная калорийность равна 996.

И так для каждого цвета.

Описанный выше процесс называется группировкой. Таким образом, группировка - это "схлопывание" (свёртка) строчек таблицы по определенному признаку.

При группировке все поля делятся на две группы:

  • Группировочные - это как раз те поля, по которым идёт свёртка. В нашем случае таким полем является Цвет.
  • Группируемые - это те поля, которые сворачиваются (схлопываются, объединяются). В нашем случае таким полем является Калорийность.

01

Группируемые поля не могут быть сами по себе. К ним обязательно применяется одна из агрегатных функций: СУММА, СРЕДНЕЕ, МИНИМУМ, МАКСИМУМ, КОЛИЧЕСТВО, КОЛИЧЕСТВО РАЗЛИЧНЫЕ:

02

Агрегатная функция СУММА

Это как раз случай, который мы разбирали. Вы читаете ознакомительную версию урока, полноценные уроки находятся здесь. Все строки группируются по группировочным полям (Цвет), а группируемые поля (Калорийностьсуммируются:

ВЫБРАТЬ
	Цвет,
	СУММА(Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

сумма

Агрегатная функция СРЕДНЕЕ

В этом случае все строки группируются по группировочным полям (Цвет), а среди группируемых полей (Калорийность) находится среднее значение:

ВЫБРАТЬ
	Цвет,
	СРЕДНЕЕ(Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

среднее

Агрегатная функция МИНИМУМ

В этом случае все строки группируются по группировочным полям (Цвет), а среди группируемых полей (Калорийность) находится минимальное значение:

ВЫБРАТЬ
	Цвет,
	МИНИМУМ(Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

минимум

Агрегатная функция МАКСИМУМ

В этом случае все строки группируются по группировочным полям (Цвет), а среди группируемых полей (Калорийность) находится максимальное значение:

ВЫБРАТЬ
	Цвет,
	МАКСИМУМ(Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

максимум

Агрегатная функция КОЛИЧЕСТВО

В этом случае все строки группируются по группировочным полям (Цвет), а среди группируемых полей (Калорийность) находится их количество:

ВЫБРАТЬ
	Цвет,
	КОЛИЧЕСТВО(Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

количество

Агрегатная функция КОЛИЧЕСТВО РАЗЛИЧНЫЕ

В этом случае все строки группируются по группировочным полям (Цвет), а среди группируемых полей (Калорийность) находится количество элементов с различными значениями:

ВЫБРАТЬ
	Цвет,
	КОЛИЧЕСТВО(РАЗЛИЧНЫЕ Калорийность)
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
	Цвет

количество различные

Функция КОЛИЧЕСТВО РАЗЛИЧНЫЕ требует пояснения, потому что на выбранном примере её результат совпадает с функцией КОЛИЧЕСТВО. Вы читаете ознакомительную версию урока, полноценные уроки находятся здесь. Вот более показательный пример, который всё объясняет:

03

Группировка без группируемых полей и агрегатных функций

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

06

К примеру, сделаем выборку всех вкусов, которые встречаются среди еды:

ВЫБРАТЬ
	Вкус
ИЗ
	Справочник.Еда

07 

Как видите вкусы повторяются - давайте их сгруппируем:

ВЫБРАТЬ
	Вкус
ИЗ
	Справочник.Еда
СГРУППИРОВАТЬ ПО
    Вкус

08 

Таким образом, мы сделали группировку только по группировочным полям (Вкус). Группируемые поля, а следовательно и агрегатные функции нам не понадобились.

Группировка без группировочных полей

Соответственно использование группировочных полей также не требуется, если результатом запроса будут только группируемые поля:

12

К примеру, получим результаты агрегатных функций применительно к полю Калорийность без группировочных полей (то есть по всей таблице):

ВЫБРАТЬ
	СУММА(Калорийность) КАК Сумма,
	СРЕДНЕЕ(Калорийность) КАК Среднее,
	МИНИМУМ(Калорийность) КАК Минимум,
	МАКСИМУМ(Калорийность) КАК Максимум,
	КОЛИЧЕСТВО(Калорийность) КАК Количество	
ИЗ
	Справочник.Еда

13

Группировка по нескольким полям

Группировочных (как впрочем и группируемых) полей может быть сколь угодно много. В запросе они перечисляются через запятую.

Пройдите тест

Начать тест

Домашнее задание

а) Напишите запрос, который группирует цвета, встречающиеся среди еды:

10 

Эталонное решение. Сначала пишем код сами, проверяем на компьютере (как и все примеры программ из уроков), только потом сверяемся

б) Напишите запрос, который находит максимальную калорийность еды для каждого цвета:

11

Эталонное решение. Сначала пишем код сами, проверяем на компьютере (как и все примеры программ из уроков), только потом сверяемся