Lorsque vous travaillez avec des champs datetime dans MySQL, il est crucial de prendre en compte l'impact de l'heure d'été heure (heure d'été). Comme l'illustre l'étude de cas, la transition de l'heure standard à l'heure d'été peut conduire à des représentations temporelles ambiguës, en particulier lors du stockage de données dans un fuseau horaire qui observe l'heure d'été.
2009-11-01 01:30:00 -04:00 vs. 2009-11-01 01:30:00 -05:00
Les deux DATETIME et les types de champs TIMESTAMP présentent des défis dans la gestion précise des données dans les fuseaux horaires observant l'heure d'été. Les champs DATETIME ne gèrent pas l'heure d'été en interne, tandis que les champs TIMESTAMP convertissent automatiquement les données vers et depuis UTC, en supposant qu'elles se trouvent dans le fuseau horaire local du système, ce qui peut entraîner une perte de données lors de la conversion aller-retour si l'heure d'été est un facteur.
Pour résoudre ce problème, il est recommandé de stocker les données date-heure dans un fuseau horaire non DST, tel que UTC. Cela vous permet de contrôler la logique de conversion en dehors de MySQL et de stocker explicitement l'équivalent UTC prévu de l'heure locale que vous souhaitez représenter.
Lors de la récupération de données de la base de données, assurez-vous de interprétez-le comme UTC en dehors de MySQL en utilisant des fonctions comme strtotime() ou la classe DateTime de PHP. Cela fournit un horodatage Unix précis, évitant toute ambiguïté.
Avant de stocker les données dans la base de données, convertissez-les à l'heure UTC souhaitée en externe à l'aide de la classe DateTime de PHP ou de mécanismes similaires. Spécifiez explicitement l'heure locale et le fuseau horaire pour garantir que la représentation UTC correcte est enregistrée dans le champ DATETIME.
N'oubliez pas que les fonctions mathématiques date/heure de MySQL peuvent ne pas fonctionner correctement autour des limites d'heure d'été si les données sont stockées dans un fuseau horaire DST. Par conséquent, le stockage des données en UTC est essentiel pour des calculs fiables.
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!