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 :

[SQL] pb de modification d'une entrée de ma bd


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 17
    Points : 12
    Points
    12
    Par défaut [SQL] pb de modification d'une entrée de ma bd
    Bonsoir,
    je peux, dans mon admin, modifier une entrée, et notamment, choisir de garder l'image 1, 2 ou 3.
    quand je choisis de garder les images, ca fonctionne. mais quand je ne souhaite pas les conserver, j'ai un bouton parcourir, pour éventuellement aller chercher une image sur mon disque dur.
    quand je ne conserve pas mes images, et que je les remplace, et bien ca ne fonctionne pas. il garde mes images de base, elles ne sont pas changées.

    voici mon code dans mon formulaire, pour choisir de garder ou non une image (je mets le code pour 1 image, le reste fut du copier coller, en changeant le numéro) :

    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
     
    <img src="<? echo $repimages_admin.$image1?>" width="75" height="57" border="1"></td>
                  <td width="170" align="left" valign="middle"><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"> 
                    <table width="87">
                      <tr> 
                        <td><font size="1" face="Verdana, Arial, Helvetica, sans-serif"> 
                          <label> 
                          <input type="radio" name="consimage1" value="oui" checked='true' onClick="document['formulaire'].userfile1.disabled=true; document['formulaire'].consimage1.value='oui'; return true">
                          <strong>Oui</strong></label>
                          </font></td>
                      </tr>
                      <tr> 
                        <td><font size="1" face="Verdana, Arial, Helvetica, sans-serif"> 
                          <label> 
                          <input type="radio" name="consimage1" value="non" onClick="document['formulaire'].userfile1.disabled=false; document['formulaire'].consimage1.value ='non'; return true">
                          <strong>Non</strong></label>
                          </font></td>
                      </tr>
                    </table>
                    </font></strong></td>
                </tr>
                <tr> 
                  <td colspan="3"><strong><font size="1" face="Verdana, Arial, Helvetica, sans-serif"><strong>Photo 
                    1 pour cette entrée</strong> : </font></strong></td>
                </tr>
                <tr> 
                  <td colspan="3"> 
                    <input name="userfile1" type=FILE id="userfile1" size="50" >
                  </td>
                </tr>
    et voici le code dans mon traitement, qui me permet de récupérer l'image :
    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
    $consimage1 =$_POST['consimage1'];
    // Si on ne conserve pas l'image 1 , on met a jour l'entrée dans la base et on met a jour la photo 1
    if ($consimage1=="non")
    {
    	// Upload de l'image
    	if(isset($_FILES['userfile1']))
    	{
    		if($_FILES['userfile1']['size']>0) 
    		{
       			$fichierimage1 = $_FILES['userfile1']['name'];
       			$savefile1= "chariot".$id_chariot."_1.jpg";
       			$temp1 = $_FILES['userfile1']['tmp_name'];
       			if (move_uploaded_file($temp1, "../".$repimages_admin.$savefile1)); 
     
    		} 
    		else
    		{
    			$savefile1="noimage1.gif";
    		}
    	} 
    	else 
    	{
        	$savefile1="noimage1.gif"; 
    	}
    }
    puis, mon code de mise à jour de ma bd (un exemple de if, car j'en ai beaucoup) :



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (($consimage1=="non")and($consimage2=="oui")and($consimage3=="oui"))
    	{
    	//Requete d'ajout de l'entrée sans toucher aux images 2 et 3
    	$sqlmodif = "UPDATE chariot SET numero='".$numero."', nom='".$nom."', chariot_souscategorie='".$chariot_souscategorie."', garantie='".$garantie."', prix='".$prix."', description='".$description."', image1='".$savefile1."' WHERE id_chariot = ".$id_chariot;
    	}
    pouvez vous me dire là ou ca cloche ?

    Merci

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 60
    Points : 81
    Points
    81
    Par défaut
    C'est un peu vague comme question... Est-ce que tu stockes les images directement dans ta base de donnée (BLOB) ou est-ce que tu stockes juste le chemin d'accès à l'image sur le disque ?

    Essaie de suivre une démarche de débuggage méthodique.

    Dans ton code html, je te conseille de noter tous tes attributs de la même façon, i.e : attribut="valeur" (donc : type="file" et pas type=FILE, mais je doute que le problème vienne de là).

    A mon avis, le problème vient du code PHP plutôt que de la page html.
    Pour le vérifier, fais un var_dump($_POST); (puisque apparament, c'est la méthode POST que tu utilises) au début de ton code de traitement, et vérifie qu'elle contient bien ce que tu attends.

    Vérifie ensuite que le fichier a bien été uploadé (il doit être présent en tmp quelque part sur ton disque dur). Il y a des limites à la taille d'un fichier uploadé, que tu peux paramétrer. Pour des raisons de sécurité, il est préférable d'utiliser is_uploaded_file() ou move_uploaded_file(), qui s'assurereront que le fichier que tu manipules provient bien d'un upload.

    Enfin, avant de faire une quelconque requête SQL, affiche les requêtes produites par ton code (i.e utilise echo plutôt que mysql_query) afin de vérifier qu'elles correspondent bien à ton attente.

    Bonne chance !

    --
    Rom_1

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    17
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 17
    Points : 12
    Points
    12
    Par défaut
    voici le var dump quand je choisis de garder la photo 1, et d'uploader une photo 2 :

    ["consimage1"]=> string(3) "oui" ["consimage2"]=> string(3) "non" ["consimage3"]=> string(3) "oui" ["SUBMIT"]=> string(21) "Modifier cette entrée" }

    ensuite, dans echo, j'ai juste mon image 1 :
    Images : chariot1_1.jpg

    alors que je devrais avoir l'image 2. donc en fait, il ne prend pas du tout en cpte l'image 2qui est uploadée.
    sinon, concernant le upload, en fait, je stockes directement l'image dans ma bd, je crois....

    pour la limite de taille, oui j'en ai une, mais le fichier que je veux uploader est bien inférieur à la limite.
    j'utilise bien move uploaded file :

    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
    // Si on ne conserve pas l'image 1 , on met a jour l'entrée dans la base et on met a jour la photo 1
    if ($consimage1=="non")
    {
    	// Upload de l'image
    	if(isset($_FILES['userfile1']))
    	{
    		if($_FILES['userfile1']['size']>0) 
    		{
       			$fichierimage1 = $_FILES['userfile1']['name'];
       			$savefile1= "chariot".$id_chariot."_1.jpg";
       			$temp1 = $_FILES['userfile1']['tmp_name'];
       			if (move_uploaded_file($temp1, "../".$repimages_admin.$savefile1)); 
     
    		} 
    		else
    		{
    			$savefile1="noimage1.gif";
    		}
    	} 
    	else 
    	{
        	$savefile1="noimage1.gif"; 
    	}
    }
    merci pour ton aide

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

Discussions similaires

  1. [1.x] [Admin Generator] Modification d'une entrée et clés étrangères
    Par dourouc05 dans le forum Symfony
    Réponses: 12
    Dernier message: 08/10/2010, 13h26
  2. Réponses: 8
    Dernier message: 16/08/2007, 13h14
  3. Bug a la modification d'une entrée dans table
    Par porci82 dans le forum VBA Access
    Réponses: 1
    Dernier message: 20/06/2007, 15h28
  4. [SQL] (PHP/SQL) Erreur de modification d'une valeur
    Par ymoreau dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 15/09/2006, 15h55
  5. VBA : modification d'une entrée dans une table
    Par Thibaut_Dupont dans le forum Access
    Réponses: 6
    Dernier message: 13/07/2006, 16h24

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