IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Warning: 1265 Data truncated for column 'age_max' at row 1


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Stagiaire en Web Développement junior
    Inscrit en
    Juillet 2019
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Belgique

    Informations professionnelles :
    Activité : Stagiaire en Web Développement junior
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2019
    Messages : 8
    Points : 6
    Points
    6
    Par défaut Warning: 1265 Data truncated for column 'age_max' at row 1
    Bonjour à tous/toutes,

    Je suis actuellement en formation webdev. Je suis en pleine construction de mon site coté admine mais je suis tombé sur cette erreur et je n'arrive pas à trouvé la solution..

    J'essaye de modifier des données dans ma BDD via un formulaire mais j'ai cette erreur qui ressort...

    ma colonne age_max etait en Int mais vu que sa ne fonctionnais pas, je l'ai changer pour la remettre en varchar. Du coup mon <input type="text" id="ageMaxEq" name="ageMaxEq" value="">
    Mais ça ne fonctionne toujours pas..
    Est ce que quelqu'un pourrait me filer un coup de main ?

    Bonne journée à tous et à toutes ^^

  2. #2
    Membre confirmé
    Homme Profil pro
    Déveleoppeur Web/Mobile
    Inscrit en
    Avril 2013
    Messages
    330
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Déveleoppeur Web/Mobile
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 330
    Points : 545
    Points
    545
    Par défaut
    Ta colonne age_max en BDD doit avoir une limite en nombre de caractères, quelle est-elle ?

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Stagiaire en Web Développement junior
    Inscrit en
    Juillet 2019
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Belgique

    Informations professionnelles :
    Activité : Stagiaire en Web Développement junior
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2019
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    Elle est en VARCHAR(5)

  4. #4
    Membre confirmé
    Homme Profil pro
    Déveleoppeur Web/Mobile
    Inscrit en
    Avril 2013
    Messages
    330
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Déveleoppeur Web/Mobile
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 330
    Points : 545
    Points
    545
    Par défaut
    Quelle valeur as tu mis par exemple dans ton input ?

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Stagiaire en Web Développement junior
    Inscrit en
    Juillet 2019
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Belgique

    Informations professionnelles :
    Activité : Stagiaire en Web Développement junior
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2019
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    Quand tu dis valeur, tu parles bien du value ?

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Stagiaire en Web Développement junior
    Inscrit en
    Juillet 2019
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Belgique

    Informations professionnelles :
    Activité : Stagiaire en Web Développement junior
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2019
    Messages : 8
    Points : 6
    Points
    6
    Par défaut Voila mon formulaire
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <form method="post" action="?">
     
    		<label for="nom">Stage Equestre</label><br>
     
    		<label for="ageMinEq">Age minimum pour le stage Equestre</label><br>
    		<input type="text" id="ageMinEq" name="ageMinEq"><br>
     
    		<label for="ageMaxEq">Age maximum pour le stage Equestre</label><br>
    		<input type="text" id="ageMaxEq" name="ageMaxEq" value=""><br>
     
    		<label for="dateDebutEq">Date début du stage Equestre</label><br>
    		<input type="date" id="dateDebutEq" name="dateDebutEq"><br>
     
    		<label for="dateFinEq">Date de fin de stage</label><br>
    		<input type="date" id="dateFinEq" name="dateFinEq" value=""><br>
     
    		<label for="description">Description:</label><br>
    		<textarea id="description" name="description" rows="5" cols="33" required></textarea><br>
     
    		<input type="submit" value="modifier" name="modifier">
     
    	</form>

  7. #7
    Membre confirmé
    Homme Profil pro
    Déveleoppeur Web/Mobile
    Inscrit en
    Avril 2013
    Messages
    330
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Déveleoppeur Web/Mobile
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 330
    Points : 545
    Points
    545
    Par défaut
    Oui, la valeur qui est mise dans ta requête UPDATE. Ça semble être un problème de type de ta colonne en BDD ou de taille limitée, il faudrait afficher la requête SQL executée et l'erreur obtenue

  8. #8
    Futur Membre du Club
    Femme Profil pro
    Stagiaire en Web Développement junior
    Inscrit en
    Juillet 2019
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : Belgique

    Informations professionnelles :
    Activité : Stagiaire en Web Développement junior
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2019
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    function modificationEq($description, $ageMinEq, $ageMaxEq, $dateDebutEq, $dateFinEq ){
     
    require(__DIR__ . "/../../config/config.php");
     
    	try{
    		// les 3 varibales sont les mêmes que dans le dossier config
    		$dbh = new PDO($info,$user,$passwordDB);
    		$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
     
    		$statement = "UPDATE stg_equestre SET description = :newDescription";
     
    		$statementPlanning = "UPDATE eq_planning SET age_min = :newAgeMin, age_max= :newAgeMax, date_debut = :newDateDebutEq, date_fin = :newDateFinEq";
     
    		$result = $dbh -> prepare($statement); 
     
    		$resultPlanning  = $dbh -> prepare($statementPlanning);
     
     
    		$result -> execute([':newDescription' => $description])/*':id' => $id]*/;
     
     
     
    		$resultPlanning -> execute([':newAgeMin' => $ageMinEq,
    									':newAgeMax' => $ageMaxEq,
    									':newDateDebutEq' => $dateDebutEq,
    									':newDateFinEq' => $dateFinEq
     
     
    		]);
     
     
     
    	}catch( Exeption $e){
     
    		echo $e->getMessage();
     
    	}
    je te met toute ma fonction pour que tu vois bien

    et quand j'ai voulu modifier mes données déjà inscrite dans ma BDD, tous c'est effacé..



    (Je suis désolé si je ne comprend pas tous de suite mais ça ne fait que 2 semaines que je commence à comprendre le php)

  9. #9
    Membre confirmé
    Homme Profil pro
    Déveleoppeur Web/Mobile
    Inscrit en
    Avril 2013
    Messages
    330
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Déveleoppeur Web/Mobile
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 330
    Points : 545
    Points
    545
    Par défaut
    Je pense que au delà du php, c'est un problème de compréhension du SQL. Un update s'utilise avec une clause WHERE, tu peux lire cette documentation
    En omettant la clause WHERE, tu modifies toutes les lignes de ta table. La clause te permet de cibler la ligne à modifier.

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    UPDATE nom_de_la_table SET ta_colonne = ta_valeur WHERE ta_condition

  10. #10
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Enregistrer aussi des ages minimum et maximum dans une colonne de type varchar n'est pas bon
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    age_min tinyint(1) unsigned,
    age_max tinyint(1) unsigned
    ces colonnes n’accepteront que des valeurs comprises entre 0 et 255, coté html tu peux aussi utiliser un input type number
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="number" name="ageMaxEq" min="10" max="50" />
    Mais il faut toujours faire une validation côté serveur.

    A+.

  11. #11
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Une validation côté serveur, ça veut dire dans la page de traitement, reposer les mêmes conditions :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if(empty($_POST['ageMaxEq']) || (! ( (int)$_POST['ageMaxEq']>=10 && (int)$_POST['ageMaxEq']<=50) ) ){
       header('location:form.php');
    }
    //et là tu peux continuer à coder tranquille, la valeur postée est bien dans les conditions attendues
    //enfin si tu as ajouté "required" dans le HTML
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

Discussions similaires

  1. [MySQL-5.7] Data truncated for column 'xx' at row 1
    Par PoelQ dans le forum MySQL
    Réponses: 4
    Dernier message: 21/04/2017, 17h53
  2. [MySQL]error 1265 (01000) data truncated for column
    Par fayabobo dans le forum Requêtes
    Réponses: 2
    Dernier message: 09/05/2011, 15h43
  3. Warning 1265: Data truncated for column
    Par el_kiko dans le forum MySQL
    Réponses: 2
    Dernier message: 01/03/2010, 20h17
  4. Data truncated for column 'idadresse' at row 1
    Par maxkarting25 dans le forum JDBC
    Réponses: 5
    Dernier message: 20/04/2009, 14h06
  5. Erreur : Data truncated for column
    Par mercure07 dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 10/12/2008, 10h20

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo