smalldatetime(Transact-SQL)
적용 대상: SQL Server Azure SQL 데이터베이스 Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System(PDW)
하루 중 시간과 결합된 날짜를 정의합니다. 시간은 하루 24시간을 기준으로 하며 초는 항상 소수 자릿수 없이 0(:00)으로 표시됩니다.
참고 항목
새 작업에는 시간, 날짜, datetime2 및 datetimeoffset 데이터 형식을 사용합니다. 이러한 데이터 형식은 SQL 표준에 맞는 형식으로, 이식성이 높습니다. time, datetime2 및 datetimeoffset 은 더 많은 초 정밀도를 제공합니다. datetimeoffset 은 전역적으로 배포된 애플리케이션에 대한 표준 시간대 지원을 제공합니다.
smalldatetime 설명
속성 | 값 |
---|---|
구문 | smalldatetime |
사용 | DECLARE @MySmalldatetime smalldatetime CREATE TABLE Table1(Column1 smalldatetime ) |
기본 문자열 리터럴 형식 (하위 수준 클라이언트에 사용됨) |
해당 없음 |
날짜 범위 | 1900-01-01부터 2079-06-06까지 1900년 1월 1일부터 2079년 6월 6일까지 |
시간 범위 | 00:00:00부터 23:59:59까지 2007-05-09 23:59:59 라운드 2007-05-10 00:00:00 |
요소 범위 | YYYY는 1900년부터 2079년까지 4자리 숫자로, 1년을 나타냅니다. MM은 지정된 연도의 월을 나타내는 01에서 12 사이의 두 자리 숫자입니다. DD는 지정된 월의 일을 나타내는 달에 따라 01에서 31까지의 두 자리 숫자입니다. hh는 시간을 나타내는 00에서 23 사이의 두 자리 숫자입니다. mm은 분을 나타내는 00에서 59 사이의 두 자리입니다. ss는 두 번째 숫자를 나타내는 00에서 59 사이의 두 자리 숫자입니다. 29.998초 이하의 값은 가장 가까운 분으로 반올림됩니다. 29.999초 이상의 값은 가장 가까운 분으로 반올림됩니다. |
문자 길이 | 최대 19개 위치 |
스토리지 크기 | 4바이트(고정) |
정확도(Accuracy) | 1분 |
Default value | 1900-01-01 00:00:00 |
캘린더 | 양력 (전체 연도 범위는 포함하지 않습니다.) |
사용자 정의 초 소수 부분 자릿수 | 아니요 |
표준 시간대 오프셋 인식 및 유지 | 아니요 |
일광 절약 시간 인식 | 아니요 |
ANSI 및 ISO 8601 호환성
smalldatetime은 ANSI 또는 ISO 8601 규격이 아닙니다.
날짜 및 시간 데이터 변환
날짜 및 시간 데이터 형식으로 변환할 때 SQL Server는 날짜 또는 시간으로 인식할 수 없는 모든 값을 거부합니다. 날짜 및 시간 데이터에 CAST 및 CONVERT 함수를 사용하는 방법은 CAST 및 CONVERT(Transact-SQL)를 참조하세요.
smalldatetime을 다른 날짜 및 시간 형식으로 변환
이 섹션에서는 smalldatetime 데이터 형식이 다른 날짜 및 시간 데이터 형식으로 변환될 때 발생하는 상황에 대해 설명합니다.
date로 변환하는 경우 년, 월, 일이 복사됩니다. 다음 코드는 값을 값 date
으로 변환한 smalldatetime
결과를 보여줍니다.
DECLARE @smalldatetime smalldatetime = '1955-12-13 12:43:10';
DECLARE @date date = @smalldatetime
SELECT @smalldatetime AS '@smalldatetime', @date AS 'date';
--Result
--@smalldatetime date
------------------------- ----------
--1955-12-13 12:43:00 1955-12-13
--
--(1 row(s) affected)
변환이 time(n)이면 시간, 분 및 초가 복사됩니다. 소수 자릿수 초는 0으로 설정됩니다. 다음 코드는 값을 값 time(4)
으로 변환한 smalldatetime
결과를 보여줍니다.
DECLARE @smalldatetime smalldatetime = '1955-12-13 12:43:10';
DECLARE @time time(4) = @smalldatetime;
SELECT @smalldatetime AS '@smalldatetime', @time AS 'time';
--Result
--@smalldatetime time
------------------------- -------------
--1955-12-13 12:43:00 12:43:00.0000
--
--(1 row(s) affected)
datetime으로 변환되면 smalldatetime 값이 datetime 값으로 복사됩니다. 소수 자릿수 초는 0으로 설정됩니다. 다음 코드는 값을 값 datetime
으로 변환한 smalldatetime
결과를 보여줍니다.
DECLARE @smalldatetime smalldatetime = '1955-12-13 12:43:10';
DECLARE @datetime datetime = @smalldatetime;
SELECT @smalldatetime AS '@smalldatetime', @datetime AS 'datetime';
--Result
--@smalldatetime datetime
------------------------- -----------------------
--1955-12-13 12:43:00 1955-12-13 12:43:00.000
--
--(1 row(s) affected)
datetimeoffset(n)으로 변환하는 경우 smalldatetime 값이 datetimeoffset(n) 값으로 복사됩니다. 소수 자릿수 초는 0으로 설정되고 표준 시간대 오프셋은 +00:0으로 설정됩니다. 다음 코드는 값을 값 datetimeoffset(4)
으로 변환한 smalldatetime
결과를 보여줍니다.
DECLARE @smalldatetime smalldatetime = '1955-12-13 12:43:10';
DECLARE @datetimeoffset datetimeoffset(4) = @smalldatetime;
SELECT @smalldatetime AS '@smalldatetime', @datetimeoffset AS 'datetimeoffset(4)';
--Result
--@smalldatetime datetimeoffset(4)
------------------------- ------------------------------
--1955-12-13 12:43:00 1955-12-13 12:43:00.0000 +00:0
--
--(1 row(s) affected)
datetime2(n)로 변환하는 경우 smalldatetime 값이 datetime2(n) 값으로 복사됩니다. 소수 자릿수 초는 0으로 설정됩니다. 다음 코드는 값을 값 datetime2(4)
으로 변환한 smalldatetime
결과를 보여줍니다.
DECLARE @smalldatetime smalldatetime = '1955-12-13 12:43:10';
DECLARE @datetime2 datetime2(4) = @smalldatetime;
SELECT @smalldatetime AS '@smalldatetime', @datetime2 AS ' datetime2(4)';
--Result
--@smalldatetime datetime2(4)
------------------------- ------------------------
--1955-12-13 12:43:00 1955-12-13 12:43:00.0000
--
--(1 row(s) affected)
예제
A. 초에서 smalldatetime으로 문자열 리터럴 캐스팅
다음 예제에서는 문자열 리터럴에서 초 변환을 비교합니다 smalldatetime
.
SELECT
CAST('2007-05-08 12:35:29' AS smalldatetime)
,CAST('2007-05-08 12:35:30' AS smalldatetime)
,CAST('2007-05-08 12:59:59.998' AS smalldatetime);
입력 | 출력 |
---|---|
2007-05-08 12:35:29 | 2007-05-08 12:35:00 |
2007-05-08 12:35:30 | 2007-05-08 12:36:00 |
2007-05-08 12:59:59.998 | 2007-05-08 13:00:00 |
B. 날짜 및 시간 데이터 형식 비교
다음 예제에서는 각 날짜 및 시간 데이터 형식에 문자열을 캐스팅한 결과를 비교합니다.
SELECT
CAST('2007-05-08 12:35:29. 1234567 +12:15' AS time(7)) AS 'time'
,CAST('2007-05-08 12:35:29. 1234567 +12:15' AS date) AS 'date'
,CAST('2007-05-08 12:35:29.123' AS smalldatetime) AS
'smalldatetime'
,CAST('2007-05-08 12:35:29.123' AS datetime) AS 'datetime'
,CAST('2007-05-08 12:35:29. 1234567 +12:15' AS datetime2(7)) AS
'datetime2'
,CAST('2007-05-08 12:35:29.1234567 +12:15' AS datetimeoffset(7)) AS
'datetimeoffset';
데이터 형식 | 출력 |
---|---|
time | 12:35:29. 1234567 |
date | 2007-05-08 |
smalldatetime | 2007-05-08 12:35:00 |
날짜/시간 | 2007-05-08 12:35:29.123 |
datetime2 | 2007-05-08 12:35:29. 1234567 |
datetimeoffset | 2007-05-08 12:35:29.1234567 +12:15 |