Ambiguous Daylight Savings Time dalam MySQL DATETIME Medan
Medan MySQL DATETIME mengemukakan teka-teki semasa peralihan waktu siang (DST). Pertimbangkan senario di mana peralihan "undur" berlaku, menghasilkan keuntungan sejam dan dua kejadian berbeza pada 1:30 pagi: 1:30 pagi -04:00 dan 1:30 pagi -05:00. Kekaburan ini timbul kerana medan DATETIME tidak menyimpan maklumat offset secara eksplisit seperti medan TIMESTAMP.
Cabaran dan Penyelesaian
Teka-teki ini menyerlahkan cabaran menyimpan data khusus masa dalam Zon waktu pemerhatian DST. Medan DATETIME atau TIMESTAMP tidak dapat mengekalkan masa yang ditentukan dengan tepat semasa peralihan tersebut. Walau bagaimanapun, wujud penyelesaian yang melibatkan penggunaan bijak medan DATETIME dan penukaran mengimbangi dalam skrip tersuai.
Medan DATETIME dan Penukaran Offset
Medan DATETIME membenarkan penyimpanan data dalam mana-mana zon waktu, termasuk zon waktu bukan DST. Dengan menukar data daripada zon waktu DST sistem kepada zon waktu bukan DST, seperti UTC, sebelum menyimpannya ke medan DATETIME, kekaburan diselesaikan. Logik penukaran boleh dilaksanakan dalam bahasa skrip yang digunakan untuk berinteraksi dengan pangkalan data.
Pendapatan dan Tafsiran
Apabila mendapatkan semula data daripada pangkalan data, proses penukaran yang sama mesti digunakan di luar MySQL untuk memastikan tafsiran yang tepat. Fungsi seperti strtotime() atau kelas DateTime dalam PHP boleh digunakan untuk mentafsir data sebagai masa UTC dan mengelakkan kekaburan yang dikaitkan dengan offset -04:00 dan -05:00.
Kesimpulan
Walaupun fungsi matematik tarikh/masa MySQL mungkin tidak mengendalikan peralihan DST dalam zon waktu pemerhatian DST, gabungan medan DATETIME dan penukaran offset eksplisit di luar MySQL menawarkan penyelesaian yang boleh dipercayai. Pendekatan ini memastikan penyimpanan yang tepat dan mendapatkan semula data khusus masa, walaupun semasa peralihan masa penjimatan siang hari.
Atas ialah kandungan terperinci Bagaimana untuk Mengendalikan Kekaburan Masa Penjimatan Siang dalam Medan DATETIME MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!