Maison >base de données >tutoriel mysql >Comment corriger les erreurs d'insertion de date « 0000-00-00 00:00:00 » dans PHP et MySQL ?

Comment corriger les erreurs d'insertion de date « 0000-00-00 00:00:00 » dans PHP et MySQL ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-31 17:44:18314parcourir

How to Fix

Format d'insertion de date PHP MySQL : résolution d'un problème de date invalide

L'insertion d'une date dans une base de données MySQL peut parfois entraîner une erreur lorsque la base de données insère uniquement '0000-00-00 00 00 00' malgré le format de date correct dans le code. Ce problème survient lorsque le format de date n'est pas reconnu par MySQL.

Pour résoudre ce problème, il est essentiel de suivre les formats de date spécifiés que MySQL accepte :

  • Chaîne Format : 'AAAA-MM-JJ' ou 'AA-MM-JJ' avec facultatif délimiteurs.
  • Format numérique :AAAAMMJJ ou AAMMJJ, à condition qu'il représente une date valide.

Dans le code donné, la date est reçue au format ' 25/08/2012', qui n'est pas reconnu par MySQL. Par conséquent, nous devons modifier le format de date vers l'un des formats pris en charge.

Options pour résoudre le problème de format de date :

  1. Configurer le sélecteur de date : Utilisez altField et <code data-type="javascript">altFormat pour spécifier le format dans lequel la date est transmise au script PHP. Par exemple, <code data-type="javascript">altFormat : "aaaa-mm-jj".
  2. Utilisez la fonction STR_TO_DATE() : Convertissez la chaîne de date au format pris en charge par MySQL à l'aide de STR_TO_DATE() fonction. Exemple :

    INSERT INTO user_date VALUES ('', '$name', STR_TO_DATE('$date', '%m/%d/%Y'))
  3. Utiliser l'objet DateTime : Convertissez la chaîne de date en un objet PHP DateTime, obtenez la chaîne formatée et utilisez-la dans la requête d'insertion. Exemple :

    $dt = \DateTime::createFromFormat('m/d/Y', $_POST['date']);
    $date = $dt->format('Y-m-d');
    
    INSERT INTO user_date VALUES ('', '$name', '$date')
  4. Manipuler la chaîne de date : Manipulez manuellement la chaîne de date pour la convertir dans un format MySQL valide. Exemple :

    $parts = explode('/', $_POST['date']);
    $date = "$parts[2]-$parts[0]-$parts[1]";
    
    INSERT INTO user_date VALUES ('', '$name', '$date')

Considérations supplémentaires :

  • Éviter l'injection SQL : Utilisez des instructions préparées avec des paramètres paramétrés requêtes pour éviter les failles de sécurité.
  • Utilisez MySQL 5.5 Recommandation : Utilisez l'extension mysqli ou PDO_MySQL au lieu des fonctions mysql_* obsolètes.
  • Considérez le type DATE : Utilisez le type MySQL DATE au lieu de DATETIME ou TIMESTAMP si vous n'en avez besoin que stocker la date sans information sur l'heure.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn