>데이터 베이스 >MySQL 튜토리얼 >SQL Server에서 UNIX 타임스탬프를 DateTime으로 변환하는 방법은 무엇입니까?

SQL Server에서 UNIX 타임스탬프를 DateTime으로 변환하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-17 16:17:10598검색

How to Convert UNIX Timestamps to DateTime in SQL Server?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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