Как вывести максимальное значение в sql
Перейти к содержимому

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

  • автор:

Функция MAX

Функция MAX возвращает максимальное значение поля среди найденных строк.

Синтаксис

SELECT MAX(поле) FROM имя_таблицы WHERE условие

Таблицы для примеров

таблица employees

id
айди
name
имя
age
возраст
salary
зарплата
1 user1 23 400
2 user2 25 500
3 user3 23 500
4 user4 30 900
5 user5 27 500
6 user6 28 900

Пример

Давайте найдем максимальное значение зарплаты в таблице:

SELECT MAX(salary) as max FROM employees

Результат выполнения SQL запроса:

max
максимальная зарплата
700

Пример

Давайте найдем максимальное значение зарплаты среди тех записей, у которых id меньше или равен 4 -м:

SELECT MAX(salary) as max FROM employees WHERE id<=4

Результат выполнения SQL запроса:

min
максимальная зарплата
600

Пример

Давайте найдем максимальное и минимальное значение зарплаты одновременно:

SELECT MAX(salary) as max, MIN(salary) as min FROM employees

Результат выполнения SQL запроса:

max
максимальная зарплата
min
минимальная зарплата
700 300

Смотрите также

  • функцию MIN ,
    которая возвращает минимальное значение

Функция 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' - последний статус.

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

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

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