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 :

Probleme UPDATE avec boucle WHILE


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Inscrit en
    Janvier 2007
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 8
    Par défaut Probleme UPDATE avec boucle WHILE
    Bonjour à tous

    je travail avec php et mysql.
    voila mon but c'est de faire une mise à jour d'une table qui contien les champs suivant: REFERENCE, NAME, AZIMUTAX ,AZIMUTXA, DISTANCE, RESULT
    et cette mise à jour concerne le champs RESULT qui doit contenir une chaine récupérée à partir de 4 select et qui peuvent être soit: OK, NOK ou ND
    et ceci sur au + quatre enregistrement.

    voila le script:

    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
    <?php session_start(); 
     
     
    $res1=$_POST['res1']; //chaine 1 du premier select
    $res2=$_POST['res2'];// deuxieme chaine 
    $res3=$_POST['res3'];// troisieme chaine
    $res4=$_POST['res4'];// quatrieme chaine
    if($res1=="value"){$res1="";}
    if($res2=="value"){$res2="";}
    if($res3=="value"){$res3="";}
    if($res4=="value"){$res4="";}
    $tab=array($res1,$res2,$res3);
     
     
    $postres=$_SESSION['postres'];// c la REFERENCE
     
     
    $db = mysql_connect('localhost', 'root', '');
    mysql_select_db('trans',$db);
    $i=-1;
    $extract=mysql_query("SELECT * FROM commande_los,concerner2 WHERE commande_los.REFERENCE ='".$postres."' AND concerner2.REFERENCE ='".$postres."'  ")or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
    $req=mysql_num_rows($extract);
    if($req>0)
    { 
     
     while($verif=mysql_fetch_array($extract))
     {$i++;
      $maj=mysql_query("UPDATE concerner2 SET RESULT ='".$tab[$i]."' WHERE REFERENCE ='".$verif['REFERENCE']."'     ")  or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error()); 
     
    }
    }
     
     
    $num=mysql_affected_rows();
     if ($num>0){
    ?>
    <div id="Layer11">
       <font size="+2">La mise à jour s'est bien déroulée </font></div> 
     
     ....etc
    la première requête SELECT c'est pour extraire les enregistrement de la table "concerner2" ayant la méme REFERENCE que la table "commande_los"
    et suivant ces enregistrements je veux faire un update avec le champs RESULT et les valeur par exemple pour 3 enregistrements: OK, NOK , NOK mais le problème j'obtiens dans mysql soit OK, OK ,OK ou bien NOK,NOK,NOK .
    la récupération des valeurs se fait correctement mais l'insertion dans les enregistrements ne se passe pas bien .
    Merci de m'eclaircir je vous serais trés reconnaissant.

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 41
    Par défaut
    Il te MAJ un boolean et pas le contenu de "$tab[$i]".

    Verfie que "$tab[$i]" renvoye bien les valeurs chaine de caractere et pas boolean.

    Sinon affiche ta requete update en dur pr voir si tu n'as pas fait d'erreur du genre dans ta boucle :


  3. #3
    Membre du Club
    Inscrit en
    Janvier 2007
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 8
    Par défaut re
    l'affichage de echo $maj donne 1
    la maj se fait mais quand par exemple je selectionne dans les select les valeur NOK, OK respectivement je devrais obtenir dans les 2 enregistrement de la base ces deux valeurs dans le champs RESULT, sauf que j'obtien dans ce cas OK,OK deux fois de suite!!

  4. #4
    Membre du Club
    Inscrit en
    Janvier 2007
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 8
    Par défaut re
    j'ai essayé avec ça aussi mais ça donne le même résultat:

    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
    $tab=array($res1,$res2,$res3,$res4);
     
     
     
    $postres=$_SESSION['postres'];
     
    $db = mysql_connect('localhost', 'root', '');
    mysql_select_db('trans',$db);
    $i=0;
    $p=count($tab);
    $cmpt=0;
    $extract=mysql_query("SELECT * FROM commande_los,concerner2 WHERE commande_los.REFERENCE ='".$postres."' AND  concerner2.REFERENCE ='".$postres."'  ")or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error());
    $req=mysql_num_rows($extract);
    if($req>0)
    {
     while(($verif=mysql_fetch_array($extract))&&($i<$p))
    {
     $cmpt= $cmpt+1; 
     
     }
    }
     
    for($i=0;$i<$cmpt;$i++)
    { 
      while($verif=mysql_fetch_array($extract))
       {
         $maj=mysql_query("UPDATE concerner2 SET RESULT ='".$tab[$i]."' WHERE REFERENCE ='".$postres."'    ")  or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error()); 
    	 }
    }
    Aidez moi svp

Discussions similaires

  1. Probleme avec boucle while
    Par enamuos dans le forum Langage
    Réponses: 2
    Dernier message: 29/12/2014, 22h43
  2. Probleme avec boucle while
    Par Slash54000 dans le forum Débuter
    Réponses: 7
    Dernier message: 22/12/2008, 09h01
  3. Réponses: 2
    Dernier message: 19/11/2006, 10h54
  4. [Debutant/WinAPI] Souci avec boucle While et GetMessage()
    Par SnowStyle dans le forum Windows
    Réponses: 11
    Dernier message: 15/10/2005, 19h19
  5. Probleme Update avec chamd decimal
    Par ouellet5 dans le forum Access
    Réponses: 1
    Dernier message: 14/10/2005, 10h57

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