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

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

  • автор:

Логические функции — GREATEST (Transact-SQL)

Эта функция возвращает максимальное значение из списка, содержащего одно или несколько выражений.

Синтаксис

GREATEST ( expression1 [ , . expressionN ] ) 

Аргументы

expression1, expressionN

Список выражений любого сопоставимого типа данных, разделенный запятыми. Функция GREATEST требует по меньшей мере один аргумент, но не более 254 аргументов.

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

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

Возвращает тип данных с наивысшим приоритетом из переданного функции набора типов. Дополнительные сведения см. в разделе Приоритет типов данных (Transact-SQL).

Если все аргументы имеют одинаковый тип данных и тип поддерживается для сравнения, GREATEST возвращает этот тип.

В противном случае функция перед сравнением неявно приводит все аргументы к типу данных с наивысшим приоритетом и использует его как тип возвращаемого значения.

Для числовых типов масштаб типа возвращаемого значения будет соответствовать масштабу аргумента, имеющего тип данных с наивысшим приоритетом, либо наибольшему масштабу, если таких аргументов несколько.

Замечания

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

Перед сравнением выполняется неявное приведение всех аргументов к типу данных с наивысшим приоритетом.

Если неявное преобразование типов между аргументами не поддерживается, функция завершится ошибкой и возвращает ошибку.

Дополнительные сведения о явном и неявном преобразовании см. в статье Преобразование типов данных (ядро СУБД).

Если один или несколько аргументов не NULL являются, NULL то аргументы игнорируются во время сравнения. Если все аргументы являются NULL , возвращается NULL GREATEST .

Сравнение символьных аргументов осуществляется в соответствии с правилами, приведенными в статье Очередность параметров сортировки.

Для сравнения не поддерживаются следующие типы: varchar(max), varbinary(max) или nvarchar(max) превышающие 8000 байт, курсор, геометрия , география, география, изображение, неупорядоченные пользователем типы, ntext, table, text и xml. GREATEST

Типы данных varchar(max), varbinary(max)и nvarchar(max) поддерживаются для аргументов, 8000 байт или меньше, и будут неявно преобразованы в varchar(n), varbinary(n)и nvarchar(n), соответственно, перед сравнением.

Например, varchar(max) может поддерживать до 8000 символов, если используется набор символов с одним байтом, а nvarchar(max) может поддерживать до 4000 байт-пар (при условии кодировки символов UTF-16).

Примеры

А. Возвращает максимальное значение из списка констант

В следующем примере возвращается максимальное значение из указанного списка констант.

Масштаб типа возвращаемого значения определяется масштабом аргумента с типом данных, имеющим наивысший приоритет.

SELECT GREATEST('6.62', 3.1415, N'7') AS GreatestVal; GO 
GreatestVal -------- 7.0000 (1 rows affected) 

B. Возвращает максимальное значение из списка констант символов

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

SELECT GREATEST('Glacier', N'Joshua Tree', 'Mount Rainier') AS GreatestString; GO 
GreatestString ------------- Mount Rainier (1 rows affected) 

C. Возвращает максимальное значение из списка аргументов столбцов

Этот пример возвращает максимальное значение из списка аргументов столбца и при сравнении игнорирует значения NULL . В этом примере используется база данных AdventureWorksLT , которую можно быстро установить в качестве образца базы данных для нового экземпляра Базы данных SQL Azure. Дополнительные сведения см. в разделе Образцы баз данных AdventureWorks.

SELECT P.Name, P.SellStartDate, P.DiscontinuedDate, PM.ModifiedDate AS ModelModifiedDate, GREATEST(P.SellStartDate, P.DiscontinuedDate, PM.ModifiedDate) AS LatestDate FROM SalesLT.Product AS P INNER JOIN SalesLT.ProductModel AS PM ON P.ProductModelID = PM.ProductModelID WHERE GREATEST(P.SellStartDate, P.DiscontinuedDate, PM.ModifiedDate) >= '2007-01-01' AND P.SellStartDate >= '2007-01-01' AND P.Name LIKE 'Touring %' ORDER BY P.Name; 

Результирующий набор: LatestDate выбирает наибольшее значение даты из трех значений, не учитывая значения NULL .

Name SellStartDate DiscontinuedDate ModelModifiedDate LatestDate -------------------- ----------------------- ------------------- ----------------------- ----------------------- Touring Pedal 2007-07-01 00:00:00.000 NULL 2009-05-16 16:34:29.027 2009-05-16 16:34:29.027 Touring Tire 2007-07-01 00:00:00.000 NULL 2007-06-01 00:00:00.000 2007-07-01 00:00:00.000 Touring Tire Tube 2007-07-01 00:00:00.000 NULL 2007-06-01 00:00:00.000 2007-07-01 00:00:00.000 (3 rows affected) 

D. Использование GREATEST с локальными переменными

В этом примере с помощью GREATEST определяется максимальное значение из списка локальных переменных в предикате предложения WHERE .

CREATE TABLE dbo.Studies ( VarX VARCHAR(10) NOT NULL, Correlation DECIMAL(4, 3) NULL ); INSERT INTO dbo.Studies VALUES ('Var1', 0.2), ('Var2', 0.825), ('Var3', 0.61); GO DECLARE @PredictionA DECIMAL(2, 1) = 0.7; DECLARE @PredictionB DECIMAL(3, 1) = 0.65; SELECT VarX, Correlation FROM dbo.Studies WHERE Correlation > GREATEST(@PredictionA, @PredictionB); GO 

Результирующий набор: Отображаются только значения, превышающие 0,7.

VarX Correlation ---------- ----------- Var2 .825 (1 rows affected) 

Д. Использование GREATEST с столбцами, константами и переменными

В этом примере с помощью GREATEST определяется максимальное значение из смешанного списка, содержащего столбцы, константы и переменные.

CREATE TABLE dbo.Studies ( VarX VARCHAR(10) NOT NULL, Correlation DECIMAL(4, 3) NULL ); INSERT INTO dbo.Studies VALUES ('Var1', 0.2), ('Var2', 0.825), ('Var3', 0.61); GO DECLARE @VarX DECIMAL(4, 3) = 0.59; SELECT VarX, Correlation, GREATEST(Correlation, 0, @VarX) AS GreatestVar FROM dbo.Studies; GO 
VarX Correlation GreatestVar ---------- --------------------- --------------------- Var1 0.200 0.590 Var2 0.825 0.825 Var3 0.610 0.610 (3 rows affected) 

Следующие шаги

  • LEAST (Transact-SQL)
  • MAX (Transact-SQL)
  • MIN (Transact-SQL)
  • CASE (Transact-SQL)
  • CHOOSE (Transact-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 .

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

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