FORMAT (Transact-SQL)
Область применения: SQL Server База данных SQL Azure Управляемый экземпляр SQL Azure конечную точку аналитики SQL Azure Synapse Analytics в хранилище Microsoft Fabric в Microsoft Fabric
Возвращает значение в указанных формате и культуре (не обязательно). Используйте функцию FORMAT
для форматирования значений даты и времени и чисел в качестве строк. Для общих преобразований типов данных используйте CAST
или CONVERT
.
Соглашения о синтаксисе Transact-SQL
Синтаксис
FORMAT( value , format [ , culture ] )
Аргументы
значение
Выражение поддерживаемого типа данных для форматирования. Список допустимых типов см. в таблице в разделе "Примечания ".
format
Шаблон формата nvarchar.
Аргумент формата должен содержать допустимую строку форматирования платформа .NET Framework как стандартную строку формата (например, "C"
или"D"
) или в виде шаблона пользовательских символов для дат и числовых значений (например, "MMMM DD, yyyy (dddd)"
). Составное форматирование не поддерживается.
Полные сведения об этих шаблонах форматирования приведены в разделах документации по .NET Framework, посвященных форматированию строк в целом, пользовательским форматам даты и времени, а также пользовательским форматам чисел. Дополнительные сведения см. в статье Типы форматирования в .NET.
Язык и региональные параметры
Необязательный аргумент nvarchar, обозначающий язык и региональные параметры.
Если аргумент языка и региональных параметров не указан, используется язык текущего сеанса. Этот язык устанавливается неявно или явно с помощью инструкции SET LANGUAGE
.
язык и региональные параметры, поддерживаемые платформа .NET Framework в качестве аргумента, не ограничиваются языками, явно поддерживаемыми SQL Server.
Если аргумент языка и региональных параметров недействителен, FORMAT
вызывает ошибку.
Типы возвращаемых данных
nvarchar или NULL
Длина возвращаемого значения определяется аргументом format.
Замечания
FORMAT
возвращает NULL
ошибки, отличные от языка и региональных параметров, которые недопустимы. Например, возвращается, NULL
если значение, указанное в формате , недопустимо.
Функция FORMAT
недетерминирована.
FORMAT
зависит от наличия среды CLR платформа .NET Framework.
Эта функция не может быть удалена, так как она зависит от наличия среды CLR. Удаленный вызов функции, требующей наличия среды CLR, может привести к ошибке на удаленном сервере.
FORMAT
использует правила форматирования среды CLR, которые определяют, что двоеточия и периоды должны быть экранированы. Таким образом, если строка форматирования (второй параметр) содержит двоеточие или период, двоеточие или период должны быть экранированы с обратной косой чертой, если входное значение (первый параметр) имеет тип данных времени . См. пример Г. Использование функции FORMAT с типами данных времени.
В приведенной ниже таблице перечислены приемлемые типы данных для аргумента value, а также содержатся сведения об их сопоставлении с эквивалентными типами .NET Framework.
Категория | Тип | Тип .NET |
---|---|---|
Числовое | bigint | Int64 |
Числовое | int | Int32 |
Числовое | smallint | Int16 |
Числовое | tinyint | Byte |
Числовое | десятичное | SqlDecimal |
Числовое | numeric | SqlDecimal |
Числовое | float | Double |
Числовое | real | Single |
Числовое | smallmoney | Decimal |
Числовое | money | Decimal |
Дата и время | date | DateTime |
Дата и время | time | TimeSpan |
Дата и время | datetime | DateTime |
Дата и время | smalldatetime | DateTime |
Дата и время | datetime2 | DateTime |
Дата и время | datetimeoffset | DateTimeOffset |
Примеры
А. Простой пример функции FORMAT
В следующем примере возвращается простой набор данных, отформатированный для различных языков и региональных параметров.
DECLARE @d AS DATE = '08/09/2024';
SELECT FORMAT(@d, 'd', 'en-US') AS 'US English',
FORMAT(@d, 'd', 'en-gb') AS 'British English',
FORMAT(@d, 'd', 'de-de') AS 'German',
FORMAT(@d, 'd', 'zh-cn') AS 'Chinese Simplified (PRC)';
SELECT FORMAT(@d, 'D', 'en-US') AS 'US English',
FORMAT(@d, 'D', 'en-gb') AS 'British English',
FORMAT(@d, 'D', 'de-de') AS 'German',
FORMAT(@d, 'D', 'zh-cn') AS 'Chinese Simplified (PRC)';
Вот результирующий набор.
US English British English German Simplified Chinese (PRC)
----------- ---------------- ----------- -------------------------
8/9/2024 09/08/2024 09.08.2024 2024/8/9
US English British English German Chinese (Simplified PRC)
----------------------- ---------------- ------------------------ -------------------------
Friday, August 9, 2024 09 August 2024 Freitag, 9. August 2024 2024年8月9日
B. Функция FORMAT с пользовательскими строками форматирования
В следующем примере показано форматирование числовых значений с помощью заданного пользовательского формата. В примере предполагается, что текущая дата — 9 августа 2024 г. Дополнительные сведения об этих и других пользовательских форматах см. в статье Пользовательские строки форматирования чисел.
DECLARE @d AS DATE = GETDATE();
SELECT FORMAT(@d, 'dd/MM/yyyy', 'en-US') AS 'Date',
FORMAT(123456789, '###-##-####') AS 'Custom Number';
Вот результирующий набор.
Date Custom Number
----------- --------------
09/08/2024 123-45-6789
В. Функция FORMAT с числовыми типами
В следующем примере возвращаются пять строк из Sales.CurrencyRate
таблицы в AdventureWorks2022
базе данных. Столбец EndOfDateRate
хранится в виде денег типа в таблице. В этом примере столбец возвращается неформатированным, затем форматируется в формате .NET Number, формате типа General и Currency. Дополнительные сведения об этих и других числовых форматах см. в статье Стандартные строки форматирования чисел.
SELECT TOP (5) CurrencyRateID,
EndOfDayRate,
FORMAT(EndOfDayRate, 'N', 'en-us') AS 'Numeric Format',
FORMAT(EndOfDayRate, 'G', 'en-us') AS 'General Format',
FORMAT(EndOfDayRate, 'C', 'en-us') AS 'Currency Format'
FROM Sales.CurrencyRate
ORDER BY CurrencyRateID;
Вот результирующий набор.
CurrencyRateID EndOfDayRate Numeric Format General Format Currency Format
-------------- ------------ -------------- -------------- ---------------
1 1.0002 1.00 1.0002 $1.00
2 1.55 1.55 1.5500 $1.55
3 1.9419 1.94 1.9419 $1.94
4 1.4683 1.47 1.4683 $1.47
5 8.2784 8.28 8.2784 $8.28
В этом примере указывается немецкий язык и региональные параметры (de-de
).
SELECT TOP (5) CurrencyRateID,
EndOfDayRate,
FORMAT(EndOfDayRate, 'N', 'de-de') AS 'Numeric Format',
FORMAT(EndOfDayRate, 'G', 'de-de') AS 'General Format',
FORMAT(EndOfDayRate, 'C', 'de-de') AS 'Currency Format'
FROM Sales.CurrencyRate
ORDER BY CurrencyRateID;
CurrencyRateID EndOfDayRate Numeric Format General Format Currency Format
-------------- ------------ -------------- -------------- ---------------
1 1.0002 1,00 1,0002 1,00 €
2 1.55 1,55 1,5500 1,55 €
3 1.9419 1,94 1,9419 1,94 €
4 1.4683 1,47 1,4683 1,47 €
5 8.2784 8,28 8,2784 8,28 €
D. Использование функции FORMAT с типами данных времени
FORMAT
возвращается NULL
в этих случаях, так как .
и :
не экранируются.
SELECT FORMAT(CAST('07:35' AS TIME), N'hh.mm'); --> returns NULL
SELECT FORMAT(CAST('07:35' AS TIME), N'hh:mm'); --> returns NULL
Функция FORMAT возвращает форматированную строку, так как символы .
и :
экранированы.
SELECT FORMAT(CAST('07:35' AS TIME), N'hh\.mm'); --> returns 07.35
SELECT FORMAT(CAST('07:35' AS TIME), N'hh\:mm'); --> returns 07:35
Формат возвращает форматируемое текущее время с заданным am или PM.
SELECT FORMAT(SYSDATETIME(), N'hh:mm tt'); --> returns 03:46 PM
SELECT FORMAT(SYSDATETIME(), N'hh:mm t'); --> returns 03:46 P
Формат возвращает указанное время, отображающее AM.
SELECT FORMAT(CAST('2018-01-01 01:00' AS DATETIME2), N'hh:mm tt'); --> returns 01:00 AM
SELECT FORMAT(CAST('2018-01-01 01:00' AS DATETIME2), N'hh:mm t'); --> returns 01:00 A
Формат возвращает указанное время, отображающее PM.
SELECT FORMAT(CAST('2018-01-01 14:00' AS DATETIME2), N'hh:mm tt'); --> returns 02:00 PM
SELECT FORMAT(CAST('2018-01-01 14:00' AS DATETIME2), N'hh:mm t'); --> returns 02:00 P
Формат возвращает указанное время в 24-часовом формате.
SELECT FORMAT(CAST('2018-01-01 14:00' AS DATETIME2), N'HH:mm'); --> returns 14:00
E. Форматирование с разделителями запятых для больших чисел
В следующем примере показано форматирование больших чисел с разделителями запятых.
SELECT FORMAT(1234567.89, 'N0') AS FormattedNumber;
Вот результирующий набор.
1,234,568
В этом примере используется описатель формата N
. Описатель N
используется для числовых значений, а число десятичных разрядов можно настроить, изменив строку формата (например, N2
для двух десятичных разрядов).
FORMAT ( value, format_string [, culture ] )
Параметры
-
value
: значение для форматирования. -
format_string
: строка, указывающая формат для применения. -
culture
: (необязательно) Строка, указывающая язык и региональные параметры, используемые для форматирования.
SELECT FORMAT(1234567.89, 'N0') AS FormattedNumber;
1,234,568