집 >데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 UNIX 타임스탬프를 DateTime으로 변환하는 방법은 무엇입니까?
SQL Server: UNIX 타임스탬프를 DateTime으로 변환
bigint
값으로 저장된 UNIX 타임스탬프는 Unix 시대(1970년 1월 1일 00:00:00 UTC) 이후 경과된 초를 나타냅니다. 이를 SQL Server의 DATETIME
형식으로 변환하면 데이터베이스 관리가 단순화됩니다.
간단한 방법은 DATEADD
:
<code class="language-sql">SELECT DATEADD(second, [unixtime], '19700101') FROM [Table];</code>
이렇게 하면 unixtime
([unixtime]
열의)가 epoch 날짜에 추가되어 해당 DATETIME
이 생성됩니다.
시대의 이해
'19700101'은 UNIX 타임스탬프 시스템의 원점인 epoch를 나타냅니다. 이 날짜에 타임스탬프를 추가하면 숫자 타임스탬프가 사람이 읽을 수 있는 날짜 및 시간으로 효과적으로 변환됩니다.
2038년 문제 해결
DATEADD
의 정수 제한(최대 2,147,483,647초)으로 인해 이 값을 초과하는 타임스탬프에 대한 문제가 발생합니다. 2038년 이후의 날짜를 처리하려면 타임스탬프를 연도로 분할하고 별도의 DATEADD
작업을 위해 남은 초 구성 요소를 포함하는 보다 강력한 접근 방식이 필요합니다. 이렇게 하면 산술 오버플로 오류를 방지할 수 있습니다.
위 내용은 SQL Server에서 UNIX 타임스탬프를 DateTime으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!