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 :

Boucle imbriquée : Arrêt après la 1ère ligne [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut Boucle imbriquée : Arrêt après la 1ère ligne
    Salut tout le monde !

    J'ai une page qui liste des matchs avec une première boucle. Afin de configurer le calendrier, je souhaite afficher dans mon form un select avec la liste des équipes.
    Le souci c'est que la boucle n'affiche que la 1ère ligne.
    Voici le code simplifié pour plus de lisibilité. Avez-vous une idée de l'erreur que j'ai faite?

    Merci d'avance !

    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
    <?
    $sql->DatabaseConnexion();
    $calendrier = $sql->query("SELECT * FROM "._MATCH_);
    $sql->DatabaseClose();
     
    	while ($results = mysql_fetch_assoc($calendrier)) {
     
    	$tpl->assign_block_vars('matchs', array(
    					'ID_MATCH' => $results['id_match'],
    					'DATE' => $results['date'],
    					'SCORE_DOM' => $results['score_dom'],
    					'SCORE_EXT' => $results['score_ext'],
    					/* Champs HIDDEN */
    					'ID_MOD' => $results['id_match'],
    					));
    	while ($equipes = mysql_fetch_assoc($calendrier)) {
        $tpl->assign_block_vars('matchs.liste_equipes', array(
    					'ID' => $equipes['id'],
    					'CLUB' => $equipes['club'],
    					));
    	}
     
    }
    ?>
    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
    <form action="" method="post" enctype="multipart/form-data">
     
            	<table>
    			<!-- BEGIN matchs -->
      				<tr>
              		<td>Date
    				<input name="m_date[]" type="text" value="{matchs.DATE}" /></td>
              		<td>Domicile<br />
    				<select name="m_equipe_dom[]">
    				<!-- BEGIN liste_equipes -->
    				<option value="{matchs.liste_equipes.ID}">{matchs.liste_equipes.CLUB}</option>
    				<!-- END liste_equipes -->
    				</select>
    				</td>
              		<td>Score dom
              		<input name="m_score_dom[]" type="text" value="{matchs.SCORE_DOM}" /></td>
              		<td>Extérieur
    				<select name="m_equipe_ext[]">
    				<!-- BEGIN liste_equipes -->
    				<option value="{matchs.liste_equipes.ID}">{matchs.liste_equipes.CLUB}</option>
    				<!-- END liste_equipes -->
    				</select>
    				</td>
              		<td>Score ext
              		<input name="m_score_ext[]" type="text" value="{matchs.MOD_SCORE_EXT}" /></td>
              		<input type="hidden" name="m_id_match[]" value="{matchs.ID_MOD}" />
      				</tr>
      			<!-- END matchs -->
      			<table>
     
    			<p>
    			<button name="submit" type="submit">Valider</button>
    			</p>
     
    </form>

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Tu essayes de boucler deux fois sur le même tableau c'est normal ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    	while ($results = mysql_fetch_assoc($calendrier)) {
    // ...
    	while ($equipes = mysql_fetch_assoc($calendrier)) {
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut
    Je souhaite utiliser le même select pour afficher les matchs et extraire les équipes qui les composent. Vu le résultat j'imagine qu'il y a un souci quelque part, cette méthode n'est pas correcte?

  4. #4
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    As-tu essayé de copier $calendrier ?

    Code php : 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
    <?
    $sql->DatabaseConnexion();
    $calendrier = $sql->query("SELECT * FROM "._MATCH_);
    $sql->DatabaseClose();
    
    $calendrier2 = $calendrier;
     
    	while ($results = mysql_fetch_assoc($calendrier)) {
     
    	$tpl->assign_block_vars('matchs', array(
    					'ID_MATCH' => $results['id_match'],
    					'DATE' => $results['date'],
    					'SCORE_DOM' => $results['score_dom'],
    					'SCORE_EXT' => $results['score_ext'],
    					/* Champs HIDDEN */
    					'ID_MOD' => $results['id_match'],
    					));
    	while ($equipes = mysql_fetch_assoc($calendrier2)) {
        $tpl->assign_block_vars('matchs.liste_equipes', array(
    					'ID' => $equipes['id'],
    					'CLUB' => $equipes['club'],
    					));
    	}
     
    }
    ?>
    
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut
    Malheureusement ça me donne le même résultat que sur mon premier message.

  6. #6
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Conceptuellement parlant ça ne me paraît pas correct.
    En effet, si ta première boucle liste les matches la seconde ne liste pas les équipes mais les matches aussi puisque ce sont les mêmes données !
    Et ce n’est pas le fait de mettre $equipes qui changera quoi que ce soit même si tu utilises d’autres champs.
    Si ta table des matches contient tous les matches d’une saison alors toutes les équipes sont présentes plusieurs fois dans les données. Donc telle que la requête est faite une même équipe apparaîtra plusieurs fois.
    Non ?
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut
    Oui c'est exact, mais comme j'ai eu le problème d'arrêt de la boucle après la première ligne, je ne me suis pas encore penché dessus.
    Faudrait-il que je créé à l’intérieur de cette première requête une seconde ou j'irais chercher les équipes en question?

  8. #8
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Pour ton premier souci. Essaie ça. Sachant que 1 ce n'est pas correct conceptuellement parlant (voir mon message précédent) et 2 que ça peut être optimisé pour ne faire qu'un seul accès à la BDD.

    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
    <?
    $sql->DatabaseConnexion();
    $calendrier = $sql->query("SELECT * FROM "._MATCH_);
    
    	while ($results = mysql_fetch_assoc($calendrier)) {
     
    	$tpl->assign_block_vars('matchs', array(
    					'ID_MATCH' => $results['id_match'],
    					'DATE' => $results['date'],
    					'SCORE_DOM' => $results['score_dom'],
    					'SCORE_EXT' => $results['score_ext'],
    					/* Champs HIDDEN */
    					'ID_MOD' => $results['id_match'],
    					));
    	
            $calendrier2 = $sql->query("SELECT * FROM "._MATCH_);      
            while ($equipes = mysql_fetch_assoc($calendrier2)) {
              $tpl->assign_block_vars('matchs.liste_equipes', array(
    					'ID' => $equipes['id'],
    					'CLUB' => $equipes['club'],
    					));
    	}
     
    }
    $sql->DatabaseClose();
    ?>
    
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut
    Alors on a le résultat inverse, la première boucle est bien lancée avec la liste des matchs mais je n'ai rien qui s'affiche dans le select des équipes.

  10. #10
    Membre émérite
    Avatar de badaze
    Homme Profil pro
    Chef de projets info
    Inscrit en
    Septembre 2002
    Messages
    1 412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets info
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2002
    Messages : 1 412
    Points : 2 522
    Points
    2 522
    Par défaut
    Le souci c’est que je ne sais pas ce que fait ton moteur de template. Pour voir ce que fait vraiment le code sans template remplace les appels tpl par un echo ou un print des valeurs.

    Pour la première boucle
    print "boucle 1".$results['id_match']."<br/>";

    Pour la seconde boucle
    print "boucle 2".$equipes['id']."<br/>";
    Cela ne sert à rien d'optimiser quelque chose qui ne fonctionne pas.

    Mon site : www.emmella.fr

    Je recherche le manuel de l'Olivetti Logos 80B.

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    110
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 110
    Points : 57
    Points
    57
    Par défaut
    Ça fonctionne !

    Je ne sais pas vraiment ce que j'ai bidouillé, je suis juste reparti du début. Est-ce que ça aurait pu venir d'un souci de cache?

    En tout cas voici le 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
    <?
    $sql->DatabaseConnexion();
    $calendrier = $sql->query("SELECT * FROM "._MATCH_);
     
     
    	while ($results = mysql_fetch_assoc($calendrier)) {
     
    	$tpl->assign_block_vars('matchs', array(
    					'ID_MATCH' => $results['id_match'],
    					'DATE' => $results['date'],
    					'SCORE_DOM' => $results['score_dom'],
    					'SCORE_EXT' => $results['score_ext'],
    					/* Champs HIDDEN */
    					'ID_MOD' => $results['id_match']
    					));
    $calendrier2 = $sql->query("SELECT * FROM "._MATCH_);	
    	while ($equipes = mysql_fetch_assoc($calendrier2)) {
        $tpl->assign_block_vars('matchs.liste_equipes', array(
    					'ID' => $equipes['id'],
    					'CLUB' => $equipes['club']
    					));
    	}
     
    }
    $sql->DatabaseClose();
    ?>
    Concernant l'affiche des équipes, je vais utiliser une autre table qui aura un ID commun qui listera les équipes participantes, ça évitera ce souci de doublons.

    Merci à vous pour vos réponses !

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

Discussions similaires

  1. Boucle macro qui s'arrête après plusieurs tours sans arriver à la fin
    Par plamouik dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 14/09/2016, 10h04
  2. [XL-2003] VBA problème avec la une boucle for range.end(xlup).row après suppression de lignes
    Par JohnNC115 dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 25/01/2011, 10h21
  3. [JTable] addRow() apres la derniere ligne
    Par Nico66 dans le forum Composants
    Réponses: 4
    Dernier message: 19/05/2005, 15h04
  4. Boucles imbriquées
    Par Immobilis dans le forum ASP
    Réponses: 28
    Dernier message: 14/01/2005, 13h17
  5. [XSL]boucle imbriquée avec condition
    Par kor dans le forum XSL/XSLT/XPATH
    Réponses: 10
    Dernier message: 11/01/2005, 14h19

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