Функции Min, Max
Возвращают наибольшее и наименьшее значения поля, заданного в запросе.
Синтаксис
Min( выражение )
Max( выражение )
Аргумент выражение представляет собой строковое выражение, определяющее поле с данными, для которых требуется выполнить расчет, или выражение, с помощью которого этот расчет производится. Операндом в выражении может быть имя таблицы, константа или функция (встроенная или определяемая пользователем, но не другая агрегатная функция SQL).
Примечания
При помощи функций Min и Max можно определить наименьшее и наибольшее значение поля на основе заданных условий агрегирования или группировки. Например, эти функции можно использовать для возвращения максимальной и минимальной стоимости доставки. Если агрегирование не задано, используется вся таблица.
Функции Min и Max можно применять в выражении запроса, в качестве свойства SQL объекта QueryDef, а также при создании набора записей на основе запроса SQL.
Примеры запросов
SELECT Min(Unitprice) as Expr1 from ProductSales;
Возвращает минимальную цену за единицу из поля «Цена» и отображает ее в столбце «Expr1».
SELECT Max(Unitprice) as Expr1 from ProductSales;
Возвращает максимальную цену за единицу из поля «Цена» и отображает в столбце xpr1.
SELECT Max(Unitprice) as MaxPrice from ProductSales;
Возвращает максимальную цену за единицу из поля «Цена» и отображает в столбце «МаксимумЦена».
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 .
Какой оператор возвращает максимальное значение поля
В статье об группировках мы обсудили, что при использовании оператора GROUP BY мы можем использовать агрегатные функции. Давайте поговорим о них поглубже .
Агрегатная функция – это функция, которая выполняет вычисление на наборе значений и возвращает одиночное значение.
MySQLSELECT [литералы, агрегатные_функции, поля_группировки] FROM имя_таблицы GROUP BY поля_группировки;Например, запрос с использованием агрегатной функции AVG может выглядеть так:
MySQLSELECT home_type, AVG(price) as avg_price FROM Rooms GROUP BY home_type
home_type avg_price Private room 89.4286 Entire home/apt 148.6667 Shared room 40 Артём Санников
Данная книга является руководством для начинающих специалистов в области анализа и обработки данных. В книге рассматривается язык SQL и его процедурное расширение PL/SQL от компании Oracle.
Главная › Базы данных › MySQL › Функции агрегирования › Функция MAX() в SQL
Функция MAX() в SQL
Математическая функция MAX() в SQL возвращает максимальное значение поля из всех найденных строк.
Синтаксис MAX()
SELECT MAX(поле_таблицы) FROM имя_таблицы WHERE условие_для_выборки;Примеры запросов
1. Вывести максимальное значение заработной платы
SELECT MAX(salary) FROM workers;2. Вывести максимальную заработную плату сотрудников по городу Екатеринбург
SELECT MAX(salary) FROM workers WHERE city = 'Екатеринбург';Записи по теме
- Функция AVG() в SQL
- Функция SUM()в SQL
- Функция COUNT() в SQL
- Что такое функции агрегирования в SQL?
- Функция MIN() в SQL

