Maison >base de données >tutoriel mysql >Comment MySQL peut-il gérer des dates/heures ambiguës lors des transitions vers l'heure d'été ?
Gestion des heures d'été ambiguës avec l'heure d'été dans MySQL
Lorsque l'heure d'été (DST) se produit, il y a une heure ambiguë où c'est difficile pour déterminer la référence temporelle prévue. Par exemple, dans le fuseau horaire Amérique/New York, 1h30 du matin peut survenir deux fois pendant la période de transition d'automne.
Problème :
Les champs DATETIME et TIMESTAMP de MySQL présentent des défis lorsqu’il s’agit de gérer ces temps ambigus. Les champs DATETIME stockent les dates et les heures telles quelles, sans tenir compte des fuseaux horaires ni des conversions DST. Les champs TIMESTAMP convertissent les horodatages d'entrée en UTC et vice versa.
Solution :
1. Utilisez les champs DATETIME :
Convertissez les horodatages en UTC avant de les stocker dans les champs DATETIME. Cela garantit que vous avez le contrôle sur l'heure UTC exacte à enregistrer.
2. Interprétation des données récupérées :
Interprétez les horodatages récupérés à partir des champs DATETIME comme des horodatages UTC en dehors de MySQL. Cela évite les ambiguïtés introduites par les fonctions date/heure de MySQL.
3. Évitez les champs TIMESTAMP :
Évitez d'utiliser les champs TIMESTAMP car ils peuvent conduire à des conversions incohérentes entre l'heure locale et UTC lorsque l'heure d'été est impliquée.
Mise en œuvre :
Récupération Données :
// Example using PHP's DateTime class $timestamp = strtotime($db_timestamp . ' UTC');
Stockage des données :
// Example using PHP's DateTime class $UTCDateTime = new DateTime('2009-11-01 1:30:00 EST'); $db_timestamp = $UTCDateTime->format('Y-m-d H:i:s');
Considérations :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!