SYSUTCDATETIME (Transact-SQL)
Возвращает значение типа datetime2, которое содержит дату и время компьютера, на котором запущен экземпляр SQL Server. Возвращаемые дата и время отображаются в формате UTC. Точность дробной части значения секунд может быть задана в диапазоне от 1 до 7 цифр. Точность по умолчанию составляет 7 цифр.
Примечание
SYSDATETIME и SYSUTCDATE имеют большую точность в долях секунды, чем GETDATE и GETUTCDATE.SYSDATETIMEOFFSET включает смещение часового пояса, заданное в системе.Функции SYSDATETIME, SYSUTCDATE и SYSDATETIMEOFFSET могут быть присвоены переменным любого типа даты и времени.
Обзор всех типов данных и функций даты и времени в языке Transact-SQL см. в разделе Типы данных и функции даты и времени.
Применимо для следующих объектов: SQL Server (SQL Server 2008 по текущую версию), База данных SQL Windows Azure (С первоначального выпуска по текущий выпуск). |
Синтаксические обозначения в Transact-SQL
Синтаксис
SYSUTCDATETIME ( )
Возвращаемый тип
datetime2
Замечания
Функция SYSUTCDATETIME может использоваться в инструкциях Transact-SQL везде, где допустимо использование выражений datetime2.
Тип SYSUTCDATETIME является недетерминированным. Невозможно проиндексировать представления и выражения, ссылающиеся на эту функцию в столбце.
Примечание
SQL Server получает значения даты и времени с помощью функции GetSystemTimeAsFileTime() Windows API.Точность зависит от физического оборудования и версии Windows, в которой запущен экземпляр SQL Server.Точность возвращаемых значений этого API-интерфейса задана равной 100 нс.Точность может быть определена с помощью метода GetSystemTimeAdjustment() API-интерфейса Windows.
Примеры
В следующих примерах с помощью шести системных функций SQL Server, которые возвращают текущую дату и время, возвращается дата, время или дата и время. Значения возвращаются последовательно и поэтому могут различаться на доли секунды.
А.Отображение форматов, которые возвращаются функциями даты и времени
В следующем примере показаны различные идентификаторы, возвращаемые функциями даты и времени.
SELECT SYSDATETIME() AS SYSDATETIME
,SYSDATETIMEOFFSET() AS SYSDATETIMEOFFSET
,SYSUTCDATETIME() AS SYSUTCDATETIME
,CURRENT_TIMESTAMP AS CURRENT_TIMESTAMP
,GETDATE() AS GETDATE
,GETUTCDATE() AS GETUTCDATE;
Ниже приводится результирующий набор.
SYSDATETIME() 2007-04-30 13:10:02.0474381
SYSDATETIMEOFFSET()2007-04-30 13:10:02.0474381 -07:00
SYSUTCDATETIME() 2007-04-30 20:10:02.0474381
CURRENT_TIMESTAMP 2007-04-30 13:10:02.047
GETDATE() 2007-04-30 13:10:02.047
GETUTCDATE() 2007-04-30 20:10:02.047
Б.Преобразование даты и времени в дату
В следующем примере показано, как преобразовать значения даты и времени в тип date.
SELECT CONVERT (date, SYSDATETIME())
,CONVERT (date, SYSDATETIMEOFFSET())
,CONVERT (date, SYSUTCDATETIME())
,CONVERT (date, CURRENT_TIMESTAMP)
,CONVERT (date, GETDATE())
,CONVERT (date, GETUTCDATE());
Ниже приводится результирующий набор.
2007-04-30
2007-04-30
2007-04-30
2007-04-30
2007-04-30
2007-04-30
В.Преобразование значений даты и времени во время
В следующем примере показано, как преобразовать значения даты и времени в тип time.
DECLARE @DATETIME DATETIME = GetDate();
DECLARE @TIME TIME
SELECT @TIME = CONVERT(time, @DATETIME)
SELECT @TIME AS 'Time', @DATETIME AS 'Date Time'
Ниже приводится результирующий набор.
Time Date Time
13:49:33.6330000 2009-04-22 13:49:33.633