Tukar lajur tarikh dan masa UTC kepada waktu tempatan dalam pernyataan SQL SELECT
Apabila melaksanakan pertanyaan SQL SELECT, mungkin perlu menukar lajur waktu tarikh UTC kepada waktu tempatan untuk meningkatkan kebolehgunaan dan meningkatkan ketepatan perwakilan data. Ini boleh dicapai melalui teknik khusus untuk versi SQL yang digunakan.
Untuk SQL Server 2008 atau lebih tinggi:
CONVERT
digabungkan dengan SWITCHOFFSET
dan CONVERT(datetimeoffset)
untuk menukar lajur UTC kepada waktu tempatan, dengan mengambil kira offset zon waktu sistem. Sintaks SQL:
<code class="language-sql">SELECT CONVERT(datetime, SWITCHOFFSET(CONVERT(datetimeoffset, MyTable.UtcColumn), DATENAME(TzOffset, SYSDATETIMEOFFSET()))) AS ColumnInLocalTime FROM MyTable</code>
DATEADD
yang lebih ringkas untuk penukaran. Sintaks SQL:
<code class="language-sql">SELECT DATEADD(mi, DATEDIFF(mi, GETUTCDATE(), GETDATE()), MyTable.UtcColumn) AS ColumnInLocalTime FROM MyTable</code>
Nota:
Elakkan menggunakan tanda tolak -
untuk menolak tarikh bagi penukaran, kerana ini mungkin membawa kepada keputusan yang tidak dapat diramalkan disebabkan keadaan perlumbaan antara sistem dan waktu tarikh tempatan.
Nota tambahan:
Kaedah yang disediakan tidak mengambil kira waktu penjimatan siang (DST). Untuk pelarasan DST, sila rujuk topik Limpahan Tindanan:
"Cara mencipta fungsi permulaan dan tamat masa penjimatan siang dalam SQL Server"
Atas ialah kandungan terperinci Bagaimana untuk Menukar Lajur Datetime UTC kepada Waktu Setempat dalam Penyata SQL SELECT?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!