SQL Server: Menukar Cap Masa UNIX kepada DateTime
Panduan ini menerangkan cara untuk menukar cap masa UNIX (disimpan sebagai bigint
) dengan cekap ke dalam DateTime
jenis data dalam SQL Server, khususnya menangani potensi "Masalah Tahun 2038."
Penukaran Standard
Kaedah mudah menggunakan fungsi DATEADD
:
<code class="language-sql">SELECT DATEADD(SECOND, [unixtime], '19700101') FROM [Table];</code>
Ini memanfaatkan zaman Unix ('1970-01-01 00:00:00 UTC') sebagai titik permulaan untuk pengiraan cap waktu.
Menangani Masalah Tahun 2038
Parameter DATEADD
fungsi second
ialah int
, mengehadkan kapasitinya. Untuk mengendalikan cap masa yang melebihi had int
(masalah Tahun 2038), kami memerlukan pendekatan yang lebih mantap.
Penyelesaian: Aritmetik Modular untuk Cap Masa Besar
Penyelesaian melibatkan pembahagian penambahan kepada tahun dan baki saat menggunakan aritmetik modular:
<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>
Kaedah ini mengendalikan cap masa dengan betul jauh melebihi tahun 2038 dengan terlebih dahulu menambah tahun dan kemudian baki saat. Ini mengelakkan ralat limpahan integer.
Atas ialah kandungan terperinci Bagaimana untuk Menukar Cap Waktu UNIX kepada DateTime dalam SQL Server, Mengendalikan Masalah Tahun 2038?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!