집 >데이터 베이스 >MySQL 튜토리얼 >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 중국어 웹사이트의 기타 관련 기사를 참조하세요!