Пример 6.14. Определение суммарной стоимости каждого товара первого сорта за каждый месяц.
Пример 6.13. Определение суммарной стоимости каждого товара за каждый месяц.
Пример 6.12. Подсчет общего количества купленного для каждой фирмы товара и его стоимости.
Пример 6.11. Подсчет количества сделок, осуществленных каждой фирмой.
Пример 6.10. Определение, на какую сумму был продан товар каждого наименования.
Пример 6.9. Вычисление среднего объема покупок, совершенных каждым покупателем.
Фраза "каждым покупателем" нашла свое отражение в SQL-запросе в виде предложения GROUP BY Клиент.Фамилия.
Пример 6.10. Определить, на какую сумму был продан товар каждого наименования.
SELECT Товар.Название,
Sum(Товар.Цена*Сделка.Количество)
AS Стоимость
FROM Товар INNER JOIN Сделка
ON Товар.КодТовара=Сделка.КодТовара
GROUP BY Товар.Название
Пример 6.11. Подсчитать количество сделок, осуществленных каждой фирмой.
SELECT Клиент.Фирма, Count(Сделка.КодСделки)
AS Количество_сделок
FROM Клиент INNER JOIN Сделка
ON Клиент.КодКлиента=Сделка.КодКлиента
GROUP BY Клиент.Фирма
Пример 6.12. Подсчитать общее количество купленного для каждой фирмы товара и его стоимость.
SELECT Клиент.Фирма, Sum(Сделка.Количество)
AS Общее_Количество,
Sum(Товар.Цена*Сделка.Количество)
AS Стоимость
FROM Товар INNER JOIN
(Клиент INNER JOIN Сделка
ON Клиент.КодКлиента=Сделка.КодКлиента)
ON Товар.КодТовара=Сделка.КодТовара
GROUP BY Клиент.Фирма
Пример 6.13. Определить суммарную стоимость каждого товара за каждый месяц.
SELECT Товар.Название, Month(Сделка.Дата)
AS Месяц,
Sum(Товар.Цена*Сделка.Количество)
AS Стоимость
FROM Товар INNER JOIN Сделка
ON Товар.КодТовара=Сделка.КодТовара
GROUP BY Товар.Название, Month(Сделка.Дата)
Пример 6.14. Определить суммарную стоимость каждого товара первого сорта за каждый месяц.
SELECT Товар.Название, Month(Сделка.Дата)
AS Месяц,
Sum(Товар.Цена*Сделка.Количество)
AS Стоимость
FROM Товар INNER JOIN Сделка
ON Товар.КодТовара=Сделка.КодТовара
WHERE Товар.Сорт="Первый"
GROUP BY Товар.Название, Month(Сделка.Дата)
При помощи HAVING отражаются все предварительно сгруппированные посредством GROUP BY блоки данных, удовлетворяющие заданным в HAVING условиям. Это дополнительная возможность "профильтровать" выходной набор.
Условия в HAVING отличаются от условий в WHERE:
HAVING исключает из результирующего набора данных группы с результатами агрегированных значений;
WHERE исключает из расчета агрегатных значений по группировке записи, не удовлетворяющие условию;
в условии поиска WHERE нельзя задавать агрегатные функции.
Пример 6.15. Определить фирмы, у которых общее количество сделок превысило три.