Перейти к содержимому

Как вывести максимальное значение в sql

  • автор:

Функция SQL MAX()

Оператор SQL MAX() — функция возвращающая максимальное значение столбца таблицы.

Функция SQL MAX() имеет следующий синтаксис:

MAX(column_name)

Примеры оператора SQL MAX: Имеется следующая таблица Universities :

ID UniversityName Students Faculties Professores Location Site
1 Perm State National Research University 12400 12 1229 Perm psu.ru
2 Saint Petersburg State University 21300 24 13126 Saint-Petersburg spbu.ru
3 Novosibirsk State University 7200 13 1527 Novosibirsk nsu.ru
4 Moscow State University 35100 39 14358 Moscow msu.ru
5 Higher School of Economics 20335 12 1615 Moscow hse.ru
6 Ural Federal University 57000 19 5640 Yekaterinburg urfu.ru
7 National Research Nuclear University 8600 10 936 Moscow mephi.ru

Пример 1: Используя оператор SQL MAX найти максимальное значение колонки Students:

SELECT MAX(Students) FROM Univerities

Пример 2: Используя оператор SQL MAX найти максимальное значение колонки Faculties, где расположение университета (Location) — Saint-Petersburg:

SELECT MAX(Faculties) FROM Universities WHERE Location = 'Saint-Petersburg'

Пример 3: Используя оператор SQL MAX найти университет (UniversityName) с наибольшим числом преподавателей (Professores):

SELECT UniversityName FROM University WHERE Professores = (SELECT MAX(Professores) FROM Universities)

Ответ: Moscow State University

MAX (Transact-SQL)

Сведения о синтаксисе Transact-SQL для SQL Server 2014 (12.x) и более ранних версиях см . в документации по предыдущим версиям.

Аргументы

ALL
Применяет агрегатную функцию ко всем значениям. ALL является параметром по умолчанию.

DISTINCT
Указывает, что учитывается каждое уникальное значение. Параметр DISTINCT не имеет смысла при использовании функцией MAX и доступен только для совместимости со стандартом ISO.

выражение
Может быть константой, именем столбца или функцией, а также любым сочетанием арифметических, побитовых и строковых операторов. MAX можно использовать со столбцами numeric, character, uniqueidentifier и datetime, но не со столбцами bit. Агрегатные функции и вложенные запросы не допускаются.

Дополнительные сведения см. в статье Выражения (Transact-SQL).

OVER (partition_by_clause [ order_by_clause ] )
partition_by_clause делит результирующий набор, полученный с помощью предложения FROM, на секции, к которым применяется функция. Если этот параметр не указан, функция обрабатывает все строки результирующего набора запроса как отдельные группы. order_by_clause определяет логический порядок, в котором выполняется операция. Аргумент partition_by_clause является обязательным. Дополнительные сведения см. в статье Предложение OVER (Transact-SQL).

Типы возвращаемых данных

Возвращает то же значение, что и expression.

Замечания

При выполнении функции MAX все значения NULL пропускаются.

MAX возвращает NULL, если нет строк для выбора.

При использовании со столбцами, содержащими символьные значения, функция MAX находит наибольшее значение в упорядоченной последовательности.

MAX — это детерминированная функция, если она используется без предложений OVER и ORDER BY. Она не детерминирована при использовании с предложениями OVER и ORDER BY. Дополнительные сведения см. в разделе Deterministic and Nondeterministic Functions.

Примеры

А. Простой пример

В следующем примере возвращается максимальная (максимальная) ставка налога в базе данных AdventureWorks2022.

SELECT MAX(TaxRate) FROM Sales.SalesTaxRate; GO 
------------------- 19.60 Warning, null value eliminated from aggregate. (1 row(s) affected) 

B. Использование предложения OVER

В следующем примере используются функции MIN, MAX, AVG и COUNT с предложением OVER для предоставления агрегированных значений для каждого отдела в таблице базы HumanResources.Department данных AdventureWorks2022.

SELECT DISTINCT Name , MIN(Rate) OVER (PARTITION BY edh.DepartmentID) AS MinSalary , MAX(Rate) OVER (PARTITION BY edh.DepartmentID) AS MaxSalary , AVG(Rate) OVER (PARTITION BY edh.DepartmentID) AS AvgSalary ,COUNT(edh.BusinessEntityID) OVER (PARTITION BY edh.DepartmentID) AS EmployeesPerDept FROM HumanResources.EmployeePayHistory AS eph JOIN HumanResources.EmployeeDepartmentHistory AS edh ON eph.BusinessEntityID = edh.BusinessEntityID JOIN HumanResources.Department AS d ON d.DepartmentID = edh.DepartmentID WHERE edh.EndDate IS NULL ORDER BY Name; 
Name MinSalary MaxSalary AvgSalary EmployeesPerDept ----------------------------- --------------------- --------------------- --------------------- ---------------- Document Control 10.25 17.7885 14.3884 5 Engineering 32.6923 63.4615 40.1442 6 Executive 39.06 125.50 68.3034 4 Facilities and Maintenance 9.25 24.0385 13.0316 7 Finance 13.4615 43.2692 23.935 10 Human Resources 13.9423 27.1394 18.0248 6 Information Services 27.4038 50.4808 34.1586 10 Marketing 13.4615 37.50 18.4318 11 Production 6.50 84.1346 13.5537 195 Production Control 8.62 24.5192 16.7746 8 Purchasing 9.86 30.00 18.0202 14 Quality Assurance 10.5769 28.8462 15.4647 6 Research and Development 40.8654 50.4808 43.6731 4 Sales 23.0769 72.1154 29.9719 18 Shipping and Receiving 9.00 19.2308 10.8718 6 Tool Design 8.62 29.8462 23.5054 6 (16 row(s) affected) 

C. Использование MAX с символьными данными

В приведенном ниже примере возвращается имя базы данных, которое является последним при сортировке по алфавиту. В нем используется WHERE database_id < 5 для обработки только системных баз данных.

SELECT MAX(name) FROM sys.databases WHERE database_id < 5; 

Последняя системная база данных — tempdb .

Как выбрать записи с максимальным значением поля для параметра с группировкой?

Заказ считается в статусе, который был добавлен последним (поле time максимальное для данного order_id).
Не могу составит запрос, которые на вход получал бы статус, а на выходе заказы (orders) с данным статусом.

select max(os.time), os.orders from order_statuses os join orders o on os.orders = o.id where os.status = 'NEW' group by os.orders;

только мой возвращает последнее время, когда у заказа был статус 'NEW', а нужно заказы, у которых 'NEW' - последний статус.

  • Вопрос задан более трёх лет назад
  • 4429 просмотров

Форум пользователей MySQL

Помогите, пожалуйста, не могу сообразить, как при группировке по дате выбрать максимальное значение второго поля?

Таблица:
id | date | number
1 | 2016-10-21 | 1
2 | 2016-10-21 | 2
3 | 2016-10-21 | 4
4 | 2016-10-22 | 1
5 | 2016-10-22 | 8
6 | 2016-10-22 | 2

Желаемый результат:
3 | 2016-10-21 | 4
5 | 2016-10-22 | 8

#2 20.06.2016 23:37:45

vasya Архат Откуда: Орел Зарегистрирован: 07.03.2007 Сообщений: 5823

Re: Как выбрать максимальное значение при группировке?

есть как минимум 5 способов
http://sqlinfo.ru/articles/info/18.html

#3 25.06.2016 19:33:41

inmerdorm Участник Зарегистрирован: 12.08.2014 Сообщений: 24

Re: Как выбрать максимальное значение при группировке?

На сколько я понимаю, там предлагается дату (timestamp) взять как за уникальное поле, а у меня даты одинаковые, и по ним нужно сгруппировать. Видимо, я чего-то недопонимаю (

#4 25.06.2016 19:54:37

vasya Архат Откуда: Орел Зарегистрирован: 07.03.2007 Сообщений: 5823

Re: Как выбрать максимальное значение при группировке?

в статье группировка идет по пользователю для которого выбирается максимальная дата
у вас группировка по дате для которой максимальный number

в примерах из статьи замените user_id на date, а time на number

#5 29.06.2016 11:13:35

inmerdorm Участник Зарегистрирован: 12.08.2014 Сообщений: 24

Re: Как выбрать максимальное значение при группировке?

Vasya, получилось, спасибо!

Однако, к текущему моменту задача усложнилась.

Необходимо в рамках текущей даты выбрать максимальный number для каждого user_id.

Таблица:
id | date | number | user_id
1 | 2016-10-21 | 1 | 1
2 | 2016-10-21 | 2 | 1
3 | 2016-10-21 | 4 | 2
4 | 2016-10-21 | 1 | 2
5 | 2016-10-22 | 8 | 1
6 | 2016-10-22 | 2 | 1
7 | 2016-10-22 | 1 | 2
8 | 2016-10-22 | 2 | 2
9 | 2016-10-22 | 4 | 2

Желаемый результат:
2 | 2016-10-21 | 2 | 1
3 | 2016-10-21 | 4 | 2
5 | 2016-10-22 | 8 | 1
9 | 2016-10-22 | 4 | 2

Чё-то никак не могу продолжить мысль, как это сделать (

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *