Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD
PHP & SGBD Forum d'entraide sur les SGBD avec PHP. Avant de poster : FAQ BDD, toutes les FAQ PHP, cours BDD et sources BDD
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 12/05/2006, 10h51   #1
Candidat au titre de Membre du Club
 
Avatar de xender
 
Inscription : décembre 2004
Messages : 92
Détails du profil
Informations forums :
Inscription : décembre 2004
Messages : 92
Points : 13
Points : 13
Par défaut [SQL] Boucle de requête SQL

Bonjour à tous !

voici mon pti problème, je voudrais insérer des valeurs dans ma base de donnée avec un boucle conditionnel.
Voici ma requète :

Code :
1
2
3
for ($i=1;$i<12;$i++){
        $result1 = mysql_query("INSERT INTO posts_commande (id_commande, ref_piece , quantite, designation, ref_appareil , num_fabric) VALUES ('$id_commande', '$ref.$i', '$qte.$i', '$designation.$i', '$ref_appareil.$i', '$numero_fabrication.$i')", $dbprotect) or die(mysql_error());
        }
Mais le problème c'est que j'ai plusieurs ligne contenant par exemple une ref qui est nommée ref1 dans mon input du formulaire.

Je récupère les valeurs des input avec ce code :
Code :
1
2
3
4
5
6
7
8
9
for ($i=1;$i<12;$i++){
        if(isset($_POST['ref'][$i])){
            $ref.$i = isset($_POST['ref'][$i]);
            $designation.$i = isset($_POST['designation'][$i]);
            $ref_appareil.$i = isset($_POST['ref_appareil'][$i]);
            $numero_fabrication.$i = isset($_POST['numero_fabrication'][$i]);
            $qte.$i = isset($_POST['qte'][$i]);
            }
        }
L'erreur retournée :
Code :
Notice: Undefined variable: ref in e:\program files\easyphp1-8\www\ci  secu\formulaire_client.php on line 79
Je sais que mon erreur est dans l'assignation du nom de mes variables dans le sql mais je ne trouve pas comment faire :-(
il faut que le code génère ref1, ref2, ref3 ...

pouvez m'expliquer la syntaxe svp?

merci d'avance
A bientôt
Xender
xender est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 10h56   #2
Membre émérite
 
Inscription : juillet 2005
Messages : 775
Détails du profil
Informations personnelles :
Âge : 29

Informations forums :
Inscription : juillet 2005
Messages : 775
Points : 858
Points : 858
Envoyer un message via AIM à ouatmad Envoyer un message via MSN à ouatmad Envoyer un message via Yahoo à ouatmad
peux tu montrer un bout d code de ton formulaire? personnellement je pense q tu es parti sur une mauvaise base. on peut passer un tableau a un formulaire au lieu d'ajouter des $i a la suite des noms
__________________
Les hommes naissent et demeurent libres et egaux en dignité et en droit. Les distinctions sociales ne peuvent etre fondées que sur l'utilité commune. Article 1 droits et de l'homme et du citoyen. 1789
ouatmad est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h03   #3
Membre Expert
 
Inscription : avril 2006
Messages : 1 338
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : avril 2006
Messages : 1 338
Points : 1 315
Points : 1 315
Je suis pas forcement plus renseigné que toi lol mais ca serait pas mieu comme ca??:

Code :
1
2
3
for ($i=1;$i<12;$i++){
        $result1 = mysql_query("INSERT INTO posts_commande (id_commande, ref_piece , quantite, designation, ref_appareil , num_fabric) VALUES ('$id_commande', '$ref[$i]', '$qte[$i]', '$designation[$i]', '$ref_appareil[$i]', '$numero_fabrication[$i]')", $dbprotect) or die(mysql_error());
        }
Code :
1
2
3
4
5
6
7
8
 
        if(isset($_POST['ref'])){
            $ref = isset($_POST['ref']);
            $designation= isset($_POST['designation']);
            $ref_appareil= isset($_POST['ref_appareil']);
            $numero_fabrication = isset($_POST['numero_fabrication']);
            $qte = isset($_POST['qte']);
        }
Comme dit ouatmad avec un tableau plus simple...
boo64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h18   #4
Candidat au titre de Membre du Club
 
Avatar de xender
 
Inscription : décembre 2004
Messages : 92
Détails du profil
Informations forums :
Inscription : décembre 2004
Messages : 92
Points : 13
Points : 13
Salut voici le code html/php de la génération des lignes input :
Code :
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
<table width="100%" border="0" align="center" cellpadding="2" cellspacing="0">
              <tr>
                <td class="fond_intitule" align="center"><div align="center">Ref pi&egrave;ce d&eacute;tach&eacute;e</div></td>
                <td class="fond_intitule" align="center"><div align="center">QTE</div></td>
                <td class="fond_intitule" align="center"><div align="center">D&eacute;signation de la pi&egrave;ce </div></td>
                <td class="fond_intitule" align="center"><div align="center">Ref. appareil</div></td>
                <td class="fond_intitule" align="center"><div align="center">N&deg; fabrication</div></td>
              </tr>
 
                    <?php 
                        $i = 1;
 
                        while ($i <= 12) {
                        ?>
                        <tr>
                        <td class="fond_formulaire" align="center">                  <div align="center">
                              <input id="ref<?php echo $i; ?>" name="ref<?php echo $i; ?>" size="6" maxlength="6" />                
                            </div></td>
                            <td class="fond_formulaire">                  <div align="center">
                              <input id="qte<?php echo $i; ?>" name="qte<?php echo $i; ?>" size="1" maxlength="1" value="1" onblur="verif_quantite(this.name,this.value);" />                
                            </div></td>
                            <td class="fond_formulaire">                    <div align="center">
                              <input id="designation<?php echo $i; ?>" name="designation<?php echo $i; ?>" size="50" maxlength="255" />                  
                            </div></td>
                            <td class="fond_formulaire">                    <div align="center">
                              <input id="ref_appareil<?php echo $i; ?>" name="ref_appareil<?php echo $i; ?>" size="10" maxlength="10" />                  
                            </div></td>
                            <td class="fond_formulaire">                    <div align="center">
                              <input id="numero_fabrication<?php echo $i; ?>" name="numero_fabrication<?php echo $i; ?>" size="10" maxlength="10" />                  
                            </div></td></tr>
                        <?php
                        $i++;
                        }    
                    ?>            
          </table>
xender est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h31   #5
Membre Expert
 
Inscription : avril 2006
Messages : 1 338
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : avril 2006
Messages : 1 338
Points : 1 315
Points : 1 315
faut que tu fasse avec un tableau c'est clair!!!!
boo64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h32   #6
Candidat au titre de Membre du Club
 
Avatar de xender
 
Inscription : décembre 2004
Messages : 92
Détails du profil
Informations forums :
Inscription : décembre 2004
Messages : 92
Points : 13
Points : 13
tu peux m'expliquer comment faire? stp
merci
xender est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h51   #7
Membre émérite
 
Inscription : juillet 2005
Messages : 775
Détails du profil
Informations personnelles :
Âge : 29

Informations forums :
Inscription : juillet 2005
Messages : 775
Points : 858
Points : 858
Envoyer un message via AIM à ouatmad Envoyer un message via MSN à ouatmad Envoyer un message via Yahoo à ouatmad
remplace ça
Code :
<input id="ref<?php echo $i; ?>" name="ref<?php echo $i; ?>
par
Code :
<input id="ref[]" name="ref[] ?>
et bien sur pas ça seulement . tu enlève les echo $i et tu met tout simplement des crochets. tu recupereras alors sous forme de tableau
__________________
Les hommes naissent et demeurent libres et egaux en dignité et en droit. Les distinctions sociales ne peuvent etre fondées que sur l'utilité commune. Article 1 droits et de l'homme et du citoyen. 1789
ouatmad est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/05/2006, 11h57   #8
Membre Expert
 
Inscription : avril 2006
Messages : 1 338
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : avril 2006
Messages : 1 338
Points : 1 315
Points : 1 315
voila pour la recup au cas ou lol
Code :
1
2
3
 
 
            $ref = isset($_POST['ref']);
boo64 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 23h28.


 
 
 
 
Partenaires

Hébergement Web