Зарегистрируйтесь для доступа к 15+ бесплатным курсам по программированию с тренажером

Функции Основы реляционных баз данных

При реализации пейджинга обычно показывают общее число страниц. Для этого надо посчитать число строк в конкретной таблице. Как это сделать? Обычная выборка уже никак не поможет, но помогут функции. SQL это больше чем просто язык запросов, это практически язык программирования, хотя и очень специфичный.

Функции, которые что-то считают по таблице, называются агрегатными. К ним относятся нахождение числа записей, суммы значений, среднего арифметического и многое другое. В этом уроке мы рассмотрим только самые популярные, полный список функций смотрите в документации.

Count

SELECT COUNT(*) FROM users;

 count
-------
    99
(1 row)

COUNT() — функция, которая считает количество записей в выборке. Подчеркну — не в таблице, а в выборке:

SELECT COUNT(*) FROM users WHERE birthday < '2018-10-21';

 count
-------
    91
(1 row)

Такой запрос вернёт ровно одну запись с одним значением — количеством строк по указанному условию.

Функция COUNT() относится к агрегирующим (агрегатным) функциям. У неё есть несколько форм:

  • Когда аргументом функции является *, она считает количество строк.
  • Если в неё передать имя конкретного поля, то она посчитает количество строк, в которых это поле НЕ равно NULL.

Max, Min

Функции MAX и MIN позволяют находить максимальное и минимальное значение соответственно.

SELECT MAX(birthday) FROM users WHERE gender = 'male';

    max
------------
 2018-12-06
 (1 row)

SELECT MIN(birthday) FROM users WHERE gender = 'female';

    min
------------
 2017-12-08
 (1 row)

Sum

Функция SUM находит сумму всех значений.

-- Получить сумму всех заказов из таблицы Orders,
-- которые были совершены в 2016 году.
SELECT SUM(amount) FROM orders
  WHERE created_at BETWEEN '2016-01-01' AND '2016-12-31';

Avg

Работа AVG

Функция AVG находит среднее арифметическое всех значений.

-- Получить среднюю стоимость всех заказов из таблицы Orders,
-- которые были совершены в 2016 году.
SELECT AVG(amount) FROM orders
  WHERE created_at BETWEEN '2016-01-01' AND '2016-12-31';

Дополнительные материалы

  1. Официальная документация

Аватары экспертов Хекслета

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты.

Для полного доступа к курсу нужен базовый план

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

Получить доступ
900
упражнений
2000+
часов теории
3200
тестов

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.

  • 130 курсов, 2000+ часов теории
  • 900 практических заданий в браузере
  • 360 000 студентов
Даю согласие на обработку персональных данных, соглашаюсь с «Политикой конфиденциальности» и «Условиями оказания услуг»

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff
Рекомендуемые программы

С нуля до разработчика. Возвращаем деньги, если не удалось найти работу.

Иконка программы Python-разработчик
Профессия
Разработка веб-приложений на Django
30 июня 10 месяцев
Иконка программы PHP-разработчик
Профессия
Разработка веб-приложений на Laravel
30 июня 10 месяцев
Иконка программы Node.js-разработчик
Профессия
Разработка бэкенд-компонентов веб-приложений
30 июня 10 месяцев
Иконка программы Fullstack-разработчик
Профессия
Новый
Разработка фронтенд и бэкенд компонентов веб-приложений
30 июня 16 месяцев
Иконка программы Java-разработчик
Профессия
Разработка приложений на языке Java
30 июня 10 месяцев

Используйте Хекслет по максимуму!

  • Задавайте вопросы по уроку
  • Проверяйте знания в квизах
  • Проходите практику прямо в браузере
  • Отслеживайте свой прогресс

Зарегистрируйтесь или войдите в свой аккаунт

Даю согласие на обработку персональных данных, соглашаюсь с «Политикой конфиденциальности» и «Условиями оказания услуг»