>데이터 베이스 >MySQL 튜토리얼 >T-SQL에서 일, 월, 연도의 날짜/시간 값을 올바르게 만드는 방법은 무엇입니까?

T-SQL에서 일, 월, 연도의 날짜/시간 값을 올바르게 만드는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-16 13:56:04515검색

How to Correctly Create a Datetime Value from Day, Month, and Year in T-SQL?

T-SQL 날짜 및 시간 값 구성: 일, 월, 연도 값에서 날짜 및 시간을 올바르게 생성 ​​

이산 날짜 구성 요소를 단일 날짜/시간 값으로 변환하는 것은 SQL Server의 일반적인 작업입니다. 이 가이드에서는 정확한 날짜 표현을 보장하기 위해 일, 월, 연도 값으로 날짜/시간을 생성하는 올바른 방법을 살펴봅니다.

문제

DATEPART 함수를 사용하여 개별 날짜 구성요소를 결합하면 종종 잘못된 결과가 생성됩니다. 질문에 제공된 CAST(DATEPART(year, DATE) '-' DATEPART(month, DATE) '-' DATEPART(day, DATE) AS DATETIME) 표현식이 날짜/시간 값을 올바르게 조합하지 않습니다.

솔루션

특정 날짜 구성요소에서 날짜/시간을 생성하는 가장 좋은 방법은 값에 대해 산술 연산을 수행하는 것입니다. 다음 문은 이러한 접근 방식을 보여줍니다.

<code class="language-sql">SELECT DateAdd(day, @DayOfMonth - 1, 
          DateAdd(month, @Month - 1, 
              DateAdd(Year, @Year-1900, 0)))</code>

이 문은 SQL Server의 날짜/시간 값의 내부 표현을 활용합니다. 여기서 첫 번째 부분은 1900년 1월 1일 이후의 일 수를 나타내고 두 번째 부분은 하루 중 소수 부분(시간)을 나타냅니다. .

대안

SQL Server 2012부터 이 목적으로 직접 사용할 수 있는 DATEFROMPARTS(year, month, day)이라는 내장 함수가 도입되었습니다.

<code class="language-sql">SELECT DATEFROMPARTS(@Year, @Month, @DayOfMonth)</code>

윤년 고려사항

윤년을 처리할 때는 항상 2월의 추가 날짜를 고려하여 연도 추가를 먼저 수행해야 합니다. 다음 수정된 문은 문제를 해결합니다.

<code class="language-sql">SELECT DateAdd(month, @Month - 1, 
     DateAdd(year, @Year-1900, @DayOfMonth - 1))</code>

결론

이러한 방법을 사용하면 개발자는 T-SQL의 개별 일, 월, 연도 구성 요소에서 날짜/시간 값을 효율적으로 생성하여 날짜 표현의 정확성과 윤년의 올바른 처리를 보장할 수 있습니다.

위 내용은 T-SQL에서 일, 월, 연도의 날짜/시간 값을 올바르게 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.