При реализации пейджинга обычно показывают общее число страниц. Для этого надо посчитать число строк в конкретной таблице. Как это сделать? Обычная выборка уже никак не поможет, но помогут функции. SQL это больше чем просто язык запросов, это практически язык программирования, хотя и очень специфичный.
Функции, которые что-то считают по таблице, называются агрегатными. К ним относятся нахождение числа записей, суммы значений, среднего арифметического и многое другое. В этом уроке мы рассмотрим только самые популярные, полный список функций смотрите в документации.
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
позволяют находить максимальное и минимальное значение соответственно.
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
находит сумму всех значений.
-- Получить сумму всех заказов из таблицы Orders,
-- которые были совершены в 2016 году.
SELECT SUM(amount) FROM orders
WHERE created_at BETWEEN '2016-01-01' AND '2016-12-31';
Функция AVG
находит среднее арифметическое всех значений.
-- Получить среднюю стоимость всех заказов из таблицы Orders,
-- которые были совершены в 2016 году.
SELECT AVG(amount) FROM orders
WHERE created_at BETWEEN '2016-01-01' AND '2016-12-31';
Вам ответят команда поддержки Хекслета или другие студенты.
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.
Наши выпускники работают в компаниях:
С нуля до разработчика. Возвращаем деньги, если не удалось найти работу.
Зарегистрируйтесь или войдите в свой аккаунт