SQL код скопирован в буфер обмена
EN PT FR

Урок 4.1: Базовые агрегатные функции в SQL

Агрегатные функции в SQL используются для выполнения вычислений над несколькими строками столбца таблицы и возвращают одно итоговое значение. Эти функции необходимы для суммирования данных, создания отчетов и проведения статистического анализа. В этом уроке рассмотрены самые распространённые агрегатные функции с практическими примерами на базе данных Sakila.

Основные агрегатные функции

COUNT() — Считает количество строк

Синтаксис:

COUNT(expression)

Пример:

SELECT COUNT(*) AS total_payments
FROM payment;

Результат: Возвращает общее количество строк в таблице payment.

COUNT(column) и COUNT(*)

Эти две формы похожи, но работают по-разному:

  • COUNT(*) считает все строки в результирующем наборе;
  • COUNT(column) считает только строки, где column имеет значение NOT NULL.

Поэтому, если в столбце есть NULL, результат COUNT(column) может быть меньше, чем COUNT(*).

Пример (Sakila):

SELECT
   COUNT(*) AS total_rentals,
   COUNT(return_date) AS returned_rentals
FROM rental;

Пояснение:

  • total_rentals считает все строки таблицы rental;
  • returned_rentals считает только строки, где return_date заполнен;
  • для невозвращённых аренд return_date = NULL, поэтому они не попадают в COUNT(return_date).

SUM() — Вычисляет сумму значений

Синтаксис:

SUM(expression)

Пример:

SELECT SUM(amount) AS total_amount
FROM payment;

Результат: Возвращает сумму значений столбца amount.

AVG() — Вычисляет среднее значение

Синтаксис:

AVG(expression)

Пример:

SELECT AVG(amount) AS average_amount
FROM payment;

Результат: Возвращает среднее значение столбца amount.

MIN() — Находит минимальное значение

Синтаксис:

MIN(expression)

Пример:

SELECT MIN(amount) AS min_amount
FROM payment;

Результат: Возвращает наименьшее значение в столбце amount.

MAX() — Находит максимальное значение

Синтаксис:

MAX(expression)

Пример:

SELECT MAX(amount) AS max_amount
FROM payment;

Результат: Возвращает наибольшее значение в столбце amount.

Практическое применение

  1. Подсчет количества клиентов: Используйте COUNT(*), чтобы узнать, сколько клиентов в базе данных.
    SELECT COUNT(*) AS total_customers
    FROM customer;
    
  2. Вычисление общей суммы продаж по сотрудникам: Используйте SUM(amount) с GROUP BY staff_id, чтобы увидеть продажи по каждому сотруднику.
    SELECT staff_id, SUM(amount) AS staff_total
    FROM payment
    GROUP BY staff_id;
    
  3. Нахождение среднего платежа по клиенту: Используйте AVG(amount) с GROUP BY customer_id.
    SELECT customer_id, AVG(amount) AS avg_payment
    FROM payment
    GROUP BY customer_id;
    

Основные выводы из этого урока

Агрегатные функции SQL — мощный инструмент для анализа и обобщения данных. Освоив COUNT, SUM, AVG, MIN и MAX, вы сможете создавать информативные отчеты и получать ценные инсайты из вашей базы данных. Практикуйтесь с этими функциями на примерах из базы Sakila для закрепления навыков.