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


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

· AVG(). Функция возвращает среднее значение столбца.

· COUNT(). Функция возвращает число строк в столбце.

· MAX(). Функция возвращает самое большое значение в столбце.

· MIN(). Функция возвращает самое маленькое значение в столбце.

· SUM(). Функция возвращает сумму значений столбца.

Пусть необходимо узнать минимальную, максимальную и среднюю цену на книги в нашем магазине. Тогда из таблицы «Цены» (prices) надо взять минимальное, максимальное и среднее значения по столбцу price. Запрос простой:

SELECT MIN(price), MAX(price), AVG(price) FROM prices;

Пусть теперь необходимо узнать, на какую сумму привез товар поставщик «Дом печати» (id = 2).

1. Сначала надо из таблицы «Поставки» (incoming) выбрать идентификаторы (id_incoming) тех поставок, которые осуществлялись поставщиком «Дом печати» (id = 2):

SELECT id_incoming FROM incoming WHERE id_vendor=2;

2. Теперь из таблицы «Журнал поставок» (magazine_incoming) надо выбрать товары (id_product) и их количества (quantity), которые осуществлялись в найденных в пункте 1 поставках. То есть запрос из пункта 1 становится вложенным:

SELECT id_product, quantity FROM magazine_incoming

WHERE id_incoming=

(SELECT id_incoming FROM incoming WHERE id_vendor=2);

3. Теперь надо добавить в результирующую таблицу цены на найденные товары, которые хранятся в таблице «Цены» (prices). Для этого понадобится объединение таблиц «Журнал поставок» (magazine_incoming) и «Цены» (prices) по столбцу id_product:

SELECT magazine_incoming.id_product, magazine_incoming.quantity, prices.price FROM magazine_incoming, prices

WHERE magazine_incoming.id_product= prices.id_product

AND id_incoming=

(SELECT id_incoming FROM incoming WHERE id_vendor=2);

4. В получившейся таблице не хватает столбца «Сумма», то есть вычисляемого столбца.

Возможность создания таких столбцов предусмотрена в MySQL. Для этого надо лишь указать в запросе имя вычисляемого столбца и что он должен вычислять.

В данном примере такой столбец будет называться summa, а вычислять он будет произведение столбцов quantity и price.

Название нового столбца отделяется словом AS:

SELECT magazine_incoming.id_product, magazine_incoming.quantity, prices.price, magazine_incoming.quantity*prices.price AS summa

FROM magazine_incoming, prices

WHERE magazine_incoming.id_product= prices.id_product

AND id_incoming=

(SELECT id_incoming FROM incoming WHERE id_vendor=2);

5. Осталось лишь просуммировать столбец summa и мы узнаем, на какую сумму привез товар поставщик «Дом печати». Синтаксис для использования функции SUM() следующий:

SELECT SUM(имя_столбца) FROM имя_таблицы;

Имя столбца известно – summa, а вот имени таблицы нет, так как она является результатом запроса.

Для таких случаев в MySQL существуют Представления.

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

Синтаксис создания представления следующий:

CREATE VIEW имя_представления AS запрос;

Сохраним наш запрос, как представление с именем report_vendor:

CREATE VIEW report_vendor AS

SELECT magazine_incoming.id_product, magazine_incoming.quantity, prices.price, magazine_incoming.quantity*prices.price AS summa

FROM magazine_incoming, prices

WHERE magazine_incoming.id_product= prices.id_product

AND id_incoming= (SELECT id_incoming FROM incoming WHERE id_vendor=2);

6. Вот теперь можно использовать итоговую функцию SUM():

SELECT SUM(summa) FROM report_vendor;



Дата добавления: 2018-05-10; просмотров: 661;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.008 сек.