Comment résoudre le problème d'horodatage 2038 de Mysql
L'horodatage fait référence au nombre total de secondes depuis 00:00:00 GMT le 1er janvier 1970 (08:00:00 le 1er janvier 1970, heure de Pékin) jusqu'à aujourd'hui.
Différentes versions de MySQL sont déployées dans l'environnement de production, dont trois versions majeures de MySQL 5.5/5.6/5.7 et N versions mineures. En raison de la mauvaise compatibilité ascendante de MySQL, le même SQL se comporte différemment dans différentes versions, comme suit L'horodatage. Le type de données est présenté en détail sous plusieurs aspects.
Accès aux données d'horodatage
Dans les trois versions majeures ci-dessus de MySQL, la plage de valeurs du type d'horodatage par défaut (Timestamp) va de ’1970-01-01 00:00:01’ 19 03:14:07’ UTC, les données sont précises au deuxième niveau. Cette plage de valeurs contient environ 2,2 milliards de valeurs, donc le type INT à 4 octets est utilisé en interne dans MySQL pour stocker les données d'horodatage :
1. Lors de l'horodatage des données, convertissez d'abord l'heure du fuseau horaire local en heure du fuseau horaire UTC, puis convertissez l'heure du fuseau horaire UTC en une valeur en millisecondes au format INT (à l'aide de la fonction UNIX_TIMESTAMP), puis stockez-la dans la base de données.
2. Lors de la lecture des données d'horodatage, convertissez d'abord la valeur en millisecondes au format INT en heure de fuseau horaire UTC (à l'aide de la fonction FROM_UNIXTIME), puis convertissez-la en heure de fuseau horaire local et enfin renvoyez-la au client.
Dans MySQL 5.6.4 et versions ultérieures, les données de type horodatage peuvent être stockées avec la plus grande précision en microsecondes (millionièmes de seconde). Le type de données est défini comme timestamp(N). La plage de valeurs de N est comprise entre 0 et 6. La valeur par défaut est 0. S'il doit être précis en millisecondes, définissez-le sur Timestamp(3). S'il doit être précis en microsecondes, définissez-le sur timestamp(6). son espace de stockage interne, mais le type d'horodatage reste inchangé. La plage de valeurs minimale et maximale de .
Définition du champ d'horodatage
La définition du champ d'horodatage affecte principalement deux types d'opérations :
Lors de l'insertion d'un enregistrement, le champ d'horodatage contient DEFAULT CURRENT_TIMESTAMP. Si aucune donnée temporelle spécifique n'est spécifiée lors de l'insertion d'un enregistrement, le champ d'horodatage. La valeur sera définie. Lors de la mise à jour d'un enregistrement pour l'heure actuelle
, le champ d'horodatage contient ON UPDATE CURRENT_TIMESTAMP Si aucune donnée temporelle spécifique n'est spécifiée lors de la mise à jour de l'enregistrement, la valeur du champ d'horodatage est définie sur l'heure actuelle
.
PS1 : CURRENT_TIMESTAMP signifie utiliser la fonction CURRENT_TIMESTAMP() pour obtenir l'heure actuelle, similaire à la fonction NOW()
Selon les deux types d'opérations ci-dessus, la colonne d'horodatage peut avoir quatre définitions de combinaison, leurs significations sont :
Lorsque le champ est défini comme horodatage, cela signifie que le champ est dans Ni l'insertion ni la mise à jour ne sont automatiquement définies sur l'heure actuelle.
Lorsqu'un champ est défini comme horodatage DEFAULT CURRENT_TIMESTAMP, cela signifie que le champ ne se verra attribuer l'heure actuelle que lorsqu'il sera inséré et qu'aucune valeur n'est spécifiée, et ne sera pas modifié lors de la mise à jour et qu'aucune valeur n'est spécifiée.
Lorsqu'un champ est défini comme horodatage ON UPDATE CURRENT_TIMESTAMP, cela signifie que le champ se voit attribuer la valeur "0000-00-00 00:00:00" lorsqu'il est inséré et qu'aucune valeur n'est spécifiée et mis à jour à l'heure actuelle. une fois mis à jour et qu'aucune valeur n'est spécifiée.
Lorsque le champ est défini comme horodatage DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, cela signifie que le champ ne spécifie pas de valeur lors de l'insertion ou de la mise à jour, et l'heure actuelle lui est attribuée.
PS1 : Il y aura des différences entre l'instruction de création de table exécutée dans MySQL et l'instruction de création de table finale. Il est recommandé d'utiliser SHOW CREATE TABLE TB_XXX pour obtenir l'instruction de création de table de la table créée.
Différences dans l'utilisation des champs d'horodatage dans différentes versions de MySQL
Dans MySQL 5.5 et les versions précédentes, seuls DEFUALT CURRENT_TIMESTAMP ou ON UPDATE CURRENT_TIMESTAMP peuvent être définis pour un champ d'horodatage, mais cela a été annulé dans MySQL 5.6 et MySQL 5.7. Cette limitation :
Dans la version MySQL 5.6, la valeur par défaut du paramètre explicit_defaults_for_timestamp est 1, dans la version MySQL 5.7, la valeur par défaut du paramètre explicit_defaults_for_timestamp est 0 ; Le type d'horodatage est par défaut NOT NULL. Dans la version MySQL 5.6, le type d'horodatage est par défaut NULL ; ON UPDATE CURRENT_TIMESTAMP;
Équivalent à l'horodatage c1 NULL DEFAULT NULL dans MySQL 5.6;
Équivalent à l'horodatage c1 NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIM ESTAMP dans MySQL 5.7 ;
-
Lorsque l'horodatage c1 est par défaut 0 est utilisé dans l'instruction de création de table,
Équivalent à l'horodatage c1 NOT NULL DEFAULT ‘0000-00-00 00:00:00’ dans MySQL 5.5
Équivalent à l'horodatage c1 NULL DEFAULT « 00 -00-00 00 dans MySQL 5.6 : 00:00 ; valeur par défaut du paramètre explicit_defaults_for_timestamp.
- PS2 : lorsque la valeur par défaut de la colonne d'horodatage est "0000-00-00 00:00:00", l'utilisation de la valeur par défaut "pas dans la plage de valeurs d'horodatage" ne générera pas d'avertissement.
-
Exception causée par le type d'horodatage
Lorsque le paramètre MySQL time_zone=system, l'interrogation du champ d'horodatage appellera le fuseau horaire du système pour la conversion du fuseau horaire. Cependant, en raison du problème de verrouillage global dans le fuseau horaire du système, des contextes de thread fréquents se produiront. lorsque plusieurs accès simultanés à des données volumineuses se produisent, l'utilisation du processeur monte en flèche, la réponse du système ralentit et l'animation est suspendue.
Type d'horodatage et sélection du type d'heure
Dans certains documents "Guide de base de données", il est recommandé d'utiliser le type d'horodatage au lieu du champ datetime. La raison est que le type d'horodatage utilise 4 octets, tandis que le champ datetime en utilise 8. octets, mais avec des performances de disque améliorées et des coûts de mémoire réduits. Dans les environnements de production réels, l'utilisation du type d'horodatage n'apportera pas beaucoup d'amélioration des performances. Au lieu de cela, la définition et la plage de valeurs du type d'horodatage peuvent limiter et affecter l'utilisation professionnelle.
Dans MySQL 5.6.4 et les versions ultérieures, les données de type d'horodatage (timestamp) peuvent être converties en microsecondes de la plus haute précision, et les données de type d'heure (datetime) peuvent également être converties en microsecondes de la plus haute précision. ) peut également obtenir le type d'horodatage. Le même effet, comme définir le champ comme dt1 DATETIME(3) NOT NULL DEFAULT NOW(3) ON UPDATE NOW(3); La plage d'accès du type d'heure (datetime) est ’1000; -01-01 00:00:00.000000&rsquo ; à "9999-12-31 23:59:59.999999", ce qui permet de mieux stocker les données de chaque période.
Recommandations pour l'utilisation des types d'horodatage
Lorsque vous vous souciez uniquement de l'heure de la dernière mise à jour des données, il est recommandé de définir la colonne d'horodatage comme TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ;
Lorsque vous vous souciez de l'heure de création et heure de mise à jour, il est recommandé de définir l'heure de mise à jour comme champ d'horodatage, de définir l'heure de création comme DAETIME ou TIMESTAMP DEFAULT ‘0000-00-00 00:00:00’ et de spécifier explicitement l'heure de création lors de l'insertion d'enregistrements
; Il est recommandé de définir uniquement une seule colonne d'horodatage et de définir explicitement les attributs DEFAULT et ON UPDATE
Bien que le champ d'horodatage puisse être attribué ou mis à jour dans MySQL, il est recommandé d'insérer et de mettre à jour explicitement la colonne d'horodatage uniquement lorsque cela est nécessaire ;
Il est recommandé de définir le paramètre time_zone sur une valeur en dehors du système. Par exemple, le serveur en Chine est défini sur "+8:00" ; Il est recommandé de conserver la version de test hors ligne de MySQL et la version de production en ligne ; cohérent. Similarités et différences entre Timestamp et datetimeMêmes points :- peut être automatiquement mis à jour et initialisé, et le format d'affichage par défaut est le même AAAA-MM-jj HH:mm:ss
- horodatage La plage est la suivante : ‘1970-01-01 00:00:01’ UTC à ‘2038-01-19 03:14:07’ stockage en octets
- La plage horaire de datetime : ‘1000-01-01 00:00:00’ à ‘9999-12-31 23:59:59’ ne prend pas en charge le fuseau horaire, le stockage sur 8 octets
CREATE TABLE `mytime` ( `id` int(11) NOT NULL AUTO_INCREMENT, `date` timestamp(6) NULL DEFAULT CURRENT_TIMESTAMP(6) ON UPDATE CURRENT_TIMESTAMP(6), `mydate` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
2038 questionQuand Si l'heure stockée de l'horodatage est supérieure à « 2038-01-19 03:14:07 » UTC, mysql signalera une erreur, car il s'agit d'un problème de mysql lui-même, ce qui signifie que l'horodatage a une limite supérieure. Si elle dépasse, une erreur sera naturellement signalée. Certaines captures d'écran sont les suivantes :
Solutionhorodatage Bien qu'il existe une limite supérieure, l'horodatage est enregistré, vous n'avez donc pas besoin de prendre en compte les problèmes de fuseau horaire si vous devez gérer les exigences liées au fuseau horaire. , vous pouvez résoudre la limite de 2038 , il est recommandé de changer l'horodatage en un type entier pour enregistrer l'horodatage puis le convertir dans le programme (cette solution n'a pas été implémentée, c'est juste une suggestion, utilisez-la avec prudence ! !)Si vous n'avez pas besoin de prendre en compte les problèmes de fuseau horaire, remplacez-le directement par l'horodatage de type datatime, car la plage de valeurs de datatime est beaucoup plus grande, vous pouvez voir l'image ci-dessus
Idées de remplacement : 1 ; . Modifiez le nom du champ d'origine ;ALTER TABLE `student` CHANGE `entry_date` `temp_entry_date` timestamp NOT NULL default '0000-00-00 00:00:00';
Créez un nouveau champ de type datatime (créez une nouvelle colonne pour remplacer l'original)ALTER TABLE `student` ADD `entry_date` DATETIME NOT NULL default '0000-00-00 00:00:00';
Copiez les données de la colonne du champ d'origine dans la nouvelle colonne de champ ; colonne d'origine ;UPDATE `student` SET `entry_date` = `temp_entry_date`;
Le sql complet est le suivant : (Il convient de noter que la valeur par défaut de l'horodatage d'origine est également requise. De plus)ALTER TABLE `student` DROP `temp_entry_date`;
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Lorsque vous traitez avec de grandes tables, les performances MySQL et la maintenabilité sont confrontées à des défis, et il est nécessaire de commencer à partir de la conception structurelle, de l'optimisation des index, de la stratégie de sous-table de tableau, etc. 1. Concevoir raisonnablement les clés et les index primaires: il est recommandé d'utiliser des entiers auto-incrémentés comme clés principales pour réduire les scintillement de pages; Utiliser les index de superposition pour améliorer l'efficacité de la requête; Analyser régulièrement les journaux de requête lents et supprimer les index non valides. 2. Utilisation rationnelle des tables de partition: partition en fonction de la plage de temps et d'autres stratégies pour améliorer l'efficacité de la requête et de la maintenance, mais l'attention devrait être accordée aux problèmes de partitionnement et de coupe. 3. Envisagez de lire et d'écrire la séparation et la séparation des bibliothèques: la séparation de lecture et d'écriture atténue la pression sur la bibliothèque principale. La séparation de la bibliothèque et la séparation des tableaux conviennent aux scénarios avec une grande quantité de données. Il est recommandé d'utiliser des middleware et d'évaluer les problèmes de requête des transactions et des magasins croisés. La planification précoce et l'optimisation continue sont la clé.

MySQL prend en charge les contraintes de contrôle pour forcer l'intégrité du domaine, efficace à partir de la version 8.0.16; 1. Ajoutez des contraintes lors de la création d'un tableau: utilisez crééTable pour définir les conditions de contrôle, telles que l'âge ≥ 18, salaire> 0, valeurs limites du département; 2. Modifiez le tableau pour ajouter des contraintes: utilisez alterTableAddConstraint pour limiter les valeurs de champ, telles que le nom non vide; 3. Utiliser des conditions complexes: Prise en charge la logique et les expressions multi-colonnes, telles que la date de fin ≥ Date et l'état d'achèvement doivent avoir une date de fin; 4. Supprimer les contraintes: utilisez alterTabledRopConstraint pour spécifier le nom à supprimer; 5. Remarques: MySQL8.0.16, Innodb ou Myisam doit être cité

Useamany-to-gyrelateeshipswithajunctiontabletolinkitemsandtagsviathreetables: éléments, tags, anditem_tags.2.whenaddingtags, checkforexistingtagsinthetagstable, insertifnecessary, thencreatemappingsinitem_tagsusingtransactionsforcencence..

Les méthodes de base pour réaliser le suivi des liens sanguins de données MySQL incluent: 1. Utilisez le binlog pour enregistrer la source de changement de données, activer et analyser le binlog et tracer des actions commerciales spécifiques en combinaison avec le contexte de la couche d'application; 2. Injecter les liens de sang dans le processus ETL et enregistrer la relation de mappage entre la source et la cible lors de la synchronisation de l'outil; 3. Ajouter des commentaires et des balises de métadonnées aux données, expliquez la source de champ lors de la construction du tableau et connectez-vous au système de gestion des métadonnées pour former une carte visuelle; 4. Faites attention à la cohérence de la clé primaire, évitez une dépendance excessive à l'égard de l'analyse SQL, des changements de modèle de données de contrôle de version et vérifiez régulièrement les données de liens sanguins pour assurer le suivi précis et fiable des liens de sang.

Vérifiez si le service MySQL est en cours d'exécution, utilisez SudosystemctlStatusMysQL pour confirmer et démarrer; 2. Assurez-vous que Bind-Address est défini sur 0,0.0.0 pour permettre les connexions distantes et redémarrer le service; 3. Vérifiez si le port 3306 est ouvert, vérifiez et configurez les règles de pare-feu pour permettre le port; 4. Pour l'erreur "AccessEnedy", vous devez vérifier le nom d'utilisateur, le mot de passe et le nom d'hôte, puis vous connecter à MySQL et interroger la table MySQL.User pour confirmer les autorisations. Si nécessaire, créez ou mettez à jour l'utilisateur et autorisez-le, comme l'utilisation de «votre_user» @ «%»; 5. Si l'authentification est perdue à cause de Caching_Sha2_Password

Pour afficher toutes les bases de données dans MySQL, vous devez utiliser la commande showDatabases; 1. Après être connecté au serveur MySQL, vous pouvez exécuter les showDatabases; Commande pour répertorier toutes les bases de données auxquelles l'utilisateur actuel a la permission d'accéder; 2. 3. Vous pouvez également interroger et filtrer la base de données via selectSchema_namefrominformation_schema.schemata; Par exemple, l'exclusion de la base de données système pour afficher uniquement la base de données créée par les utilisateurs; Assurez-vous d'utiliser

DeleterMovesspecificorAllRows, KeepSableStructure, permet de faire des effectifs et de surgurer de manière

CheckCompatibilitéwithos, Applications et Features; 2.BackupallData, Configs, andlogs; 3.ChooseupgradeMethod (PackageManager, MySQLinstaller, Ormanual); 4.Runpost-upgradeCkEckSandtests; 5.ResolvessueslikEuthenticationpluginsordepreatedOptions.
