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 :

Message d'erreur "Column count doesn't match value count at row 1" [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 53
    Points : 43
    Points
    43
    Par défaut Message d'erreur "Column count doesn't match value count at row 1"
    Salut!

    j'ai un probleme dans mon code,lorsque je clique sur le bouton "créer ce programme" un message d'erreur s'affiche "Column count doesn't match value count at row 1'
    voici mon code
    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
     
    <? require_once('classconnexion.php') ?>
    <?php
     
     
    session_start(); // On relaye la session
    if (session_is_registered("authentification") && $_SESSION['privilege'] == "admin")
    { 
     
    }
    else {
    header("Location:authentification.php?erreur=intru"); // redirection en cas d'echec
    }
    ?>
    <?php 
    // ------ AJOUT D'UN PROGRAMME --------
    if(isset($_POST['dated'])){
     
    	if(($_POST['dated']  == "")|| ($_POST['datef'] == "")|| ($_POST['lieu'] == "")|| ($_POST['hotel'] == "")){
     
    		header("Location:prog.php?erreur=empty");
    	 }
       else { 
    		$dated = $_POST['dated'];
    		$df = $_POST['datef'];
    		$lieu = $_POST['lieu'];
    		$hotel = $_POST['hotel'];
     
    		// on fait l'INSERT dans la base de données
    		$add_user = sprintf("INSERT INTO  programme (dated,datef,lieu,hotel) VALUES ('$dated,$df,$lieu,$hotel')");
     
      $dbprotect = mysql_pconnect("localhost","root", "") or trigger_error(mysql_error(),E_USER_ERROR); 
    mysql_select_db('conférence1', $dbprotect);
      		$result = mysql_query($add_user,$dbprotect) or die(mysql_error());
    		header("Location:prog.php?add=ok"); 
    			}
     
    }
     
    // ------ SUPPRESSION D'UN PROGRAMME --------
     
    $dbprotect = mysql_pconnect("localhost","root", "") or trigger_error(mysql_error(),E_USER_ERROR); 
    mysql_select_db('conférence1', $dbprotect);
     
    $query_users = "SELECT * FROM programme "; 
    $users = mysql_query($query_users,$dbprotect) or die(mysql_error());
    $row_users = mysql_fetch_assoc($users);
     
    if(isset($_POST['suppr']) && ($_POST['suppr'] != "1")){ 
    	$id = $_POST['suppr'];
        $delete_user = sprintf("DELETE FROM programme WHERE id='$id'");
    	$dbprotect = mysql_pconnect("localhost","root", "") or trigger_error(mysql_error(),E_USER_ERROR); 
    mysql_select_db('conférence1', $dbprotect);
     
      $result = mysql_query($delete_user,$dbprotect) or die(mysql_error());
      header("Location:prog.php?delete=ok"); 
    }
    ?>
     
     
    <html>
    <head>
    <title>ADMINISTRATION </title>
    <link href="styles.css" rel="stylesheet" type="text/css">
    </head>
    <body>
    <form action="" method="post" name="add">
     <div class="titre">- : : : ESPACE ADMINISTRATION : : : -</div> 
     <p align="center">
     
               <?php if(isset($_GET['add']) && ($_GET['add'] == "ok")) { // Affiche l'erreur ?>
        <span class="reussite">Le programme a &eacute;t&eacute; cr&eacute;&eacute; avec succ&egrave;s !</span>
        <?php } ?>
        <?php if(isset($_GET['erreur']) && ($_GET['erreur'] == "empty")) { // Affiche l'erreur  ?>
        <span class="erreur">Un petit oubli non ? Veuillez renseigner tous les champs SVP</span>
        <?php } ?>
    </p>
      <p align="center"><strong><u>Cr&eacute;er un programme</u></strong></p>
      <table width="350" border="0" align="center" cellpadding="5" cellspacing="0" bgcolor="#eeeeee" class="tableaux">
        <tr>
          <td width="40">Date d&eacute;but</td>
          <td width="144"><input name="dated" type="text" id="dated"></td>
        </tr>
        <tr>
          <td width="40">Date fin</td>
          <td width="144"><input name="datef" type="text" id="datef"></td>
        </tr>
    	<tr>
          <td width="40">Lieu</td>
          <td width="144"><input name="lieu" type="text" id="lieu"></td>
        </tr>
    	<tr>
          <td width="40">Hotel</td>
          <td width="144"><input name="hotel" type="text" id="hotel"></td>
        </tr>
        <tr>
          <td height="50" colspan="2"><div align="center">
              <input type="submit" name="Submit" value="Cr&eacute;er ce programme">
            </div></td>
        </tr>
      </table>
    </form>
    <p align="center"><strong>
      <?php 
    if(isset($_GET['delete']) && ($_GET['delete'] == "ok")) { // Affiche l'erreur  ?>
      <span class="reussite">La famille a &eacute;t&eacute; supprim&eacute; avec succ&egrave;s</span>
      <?php } ?>
      <?php 
    if(isset($_POST['verif']) && (!isset($_POST['suppr']))) { // Affiche l'erreur  ?>
    </strong><span class="erreur">Veuillez s&eacute;lectionner le programme &agrave; supprimer </span>
    <?php } ?>
     
    <form action="" method="post" name="suppr">
      <p align="center"><strong><u>Supprimer un programme</u></strong></p>
      <div align="center"><table width="500" border="0" cellpadding="5" cellspacing="0" class="tableaux">
          <tr>
            <td width="240"><div align="center">
              <select name="suppr" size="5" id="select1">
                 <?php
    	do {  
    ?>
                  <option value="<?php echo $row_users['id']?>">
                  <?php  echo $row_users['dated']." ". $row_users['lieu']." (".$row_users['hotel'].")";; ?>
                  </option>
                  <?php
    	} while ($row_users = mysql_fetch_assoc($users));
    	 		$rows = mysql_num_rows($users);
      		if($rows > 0) {
          		mysql_data_seek($users, 0);
    	  		$row_users = mysql_fetch_assoc($users);
    		}
    ?>
              </select>
              <input name="verif" type="hidden" id="verif">
            </div></td>
            <td width="157"><input type="submit" name="Submit2" value="Supprimer ce programme"></td>
          </tr>
        </table>
     
        <p><a href="acceuil.php"><strong>&lt; Retour accueil</strong></a></p>
      </div>
    </form>
     
    </body>
    </html>
    Voici la table dans la BD:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    CREATE TABLE `programme` (
      `id` int(10) unsigned NOT NULL auto_increment,
      `dated` date NOT NULL,
      `datef` date NOT NULL,
      `lieu` varchar(20) NOT NULL,
      `hotel` varchar(20) NOT NULL,
      PRIMARY KEY  (`id`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=16 ;
    Merci d'avance

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juillet 2009
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2009
    Messages : 10
    Points : 6
    Points
    6
    Par défaut
    Salut,
    à mon avis ça viens de ton insert dans la table 'programme' dont la 1er colonne est auto_increment

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    // on fait l'INSERT dans la base de données
    $add_user = sprintf("INSERT INTO  programme (dated,datef,lieu,hotel) VALUES ('$dated,$df,$lieu,$hotel')");
    tu ne met que 4 valeurs alors que tu as 5 colonnes essaye avec 'NULL' pour la colonne id.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    // on fait l'INSERT dans la base de données
    $add_user = sprintf("INSERT INTO  programme (id,dated,datef,lieu,hotel) VALUES (NULL,'$dated','$df','$lieu','$hotel')");
    je ne suis pas un expert, c'est le seul problème qui me saute aux yeux

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 144
    Points : 161
    Points
    161
    Par défaut
    Non, la colonne en auto-increment s'insèrera tout seule.

    Par contre ça : '$dated,$df,$lieu,$hotel' c'est une valeur (une chaîne de caractères), pas 4...

  4. #4
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par Adrien37 Voir le message
    Salut,
    à mon avis ça viens de ton insert dans la table 'programme' dont la 1er colonne est auto_increment



    tu ne met que 4 valeurs alors que tu as 5 colonnes essaye avec 'NULL' pour la colonne id.



    je ne suis pas un expert, c'est le seul problème qui me saute aux yeux
    Merci pour l'effort

  5. #5
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par asdf007 Voir le message
    Non, la colonne en auto-increment s'insèrera tout seule.

    Par contre ça : '$dated,$df,$lieu,$hotel' c'est une valeur (une chaîne de caractères), pas 4...
    Merci bien,mais j'ai pas tout à fait compris

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 144
    Points : 161
    Points
    161
    Par défaut
    Citation Envoyé par loviso Voir le message
    Merci bien,mais j'ai pas tout à fait compris
    Ton INSERT précise 4 colonnes. Tu n'en passes qu'une, qui regroupe tes 4 valeurs dans une même chaine de caractères.

    Affiche ton SQL (echo $add_user) et tu comprendras.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    625
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 625
    Points : 822
    Points
    822
    Par défaut
    Accessoirement, jette aussi un oeil sur la doc de sprintf().

    Cette fonction ne s'utilise pas de cette manière (même si ça fonctionne).

  8. #8
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 144
    Points : 161
    Points
    161
    Par défaut
    Effectivement, ça sert pas des masses avec un seul argument, sprintf.

  9. #9
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par asdf007 Voir le message
    Ton INSERT précise 4 colonnes. Tu n'en passes qu'une, qui regroupe tes 4 valeurs dans une même chaine de caractères.

    Affiche ton SQL (echo $add_user) et tu comprendras.

    Merci bien,ça a marché j'ai corrigé l'erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $add_user = sprintf("INSERT INTO  programme (dated,datef,lieu,hotel) VALUES ('$dated','$df','$lieu','$hotel')");
    Merci à tous.

  10. #10
    Membre du Club
    Inscrit en
    Août 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 53
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par Petibidon Voir le message
    Accessoirement, jette aussi un oeil sur la doc de sprintf().

    Cette fonction ne s'utilise pas de cette manière (même si ça fonctionne).
    Citation Envoyé par asdf007 Voir le message
    Effectivement, ça sert pas des masses avec un seul argument, sprintf.

    MERCI pour vos conseils,je vais faire un coup d'œil sur la doc .

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [MySQL] Column count doesn't match value count at row 1
    Par RACKER59 dans le forum PHP & Base de données
    Réponses: 37
    Dernier message: 23/11/2007, 18h37
  2. Réponses: 7
    Dernier message: 06/10/2007, 00h17
  3. [MySQL] #1136 - Column count doesn't match value count at row 1
    Par LestoK dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 13/07/2007, 11h18
  4. Réponses: 4
    Dernier message: 19/04/2007, 22h37
  5. Réponses: 2
    Dernier message: 23/03/2007, 15h29

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