SQL Server:將 UNIX 時間戳記轉換為日期時間
本指南介紹如何在 SQL Server 中有效地將 UNIX 時間戳記(儲存為 bigint
)轉換為 DateTime
資料類型,特別是解決潛在的「2038 年問題」。
標準轉換
一個簡單的方法使用 DATEADD
函數:
<code class="language-sql">SELECT DATEADD(SECOND, [unixtime], '19700101') FROM [Table];</code>
這利用 Unix 紀元 ('1970-01-01 00:00:00 UTC') 作為時間戳記計算的起點。
解決 2038 年問題
DATEADD
函數的second
參數是一個int
,限制了它的容量。 為了處理超過 int
限制的時間戳(2038 年問題),我們需要一種更穩健的方法。
解:大時間戳的模組化演算法
解涉及使用模運算將加法分解為年和剩餘秒:
<code class="language-sql">DECLARE @t BIGINT = 4147483645; DECLARE @oneyear INT = 31622400; -- Approximate seconds in a year SELECT (@t / @oneyear) AS YearsToAdd; -- Number of years SELECT (@t % @oneyear) AS RemainingSeconds; -- Remaining seconds -- Calculate the DateTime SELECT DATEADD(SECOND, @t % @oneyear, DATEADD(YEAR, @t / @oneyear, '19700101'));</code>
此方法透過先加入年份,然後再加入剩餘的秒數,正確處理遠遠超出 2038 年的時間戳記。 這可以避免整數溢位錯誤。
以上是如何在 SQL Server 中將 UNIX 時間戳記轉換為日期時間,處理 2038 年問題?的詳細內容。更多資訊請關注PHP中文網其他相關文章!