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

Langage PHP Discussion :

Bug dans une boucle php


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 2
    Par défaut Bug dans une boucle php
    Bonjour, j'aimerais réaliser une galerie, mais je bute sur un bug dans ma boucle php.

    Voici mon problème :

    J'ai 2 tables :

    Table1


    Table2


    et voici mon code PHP :






    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
    <?php
    	$db = mysql_connect('127.0.0.1', 'root', '');
    	mysql_select_db('test',$db);
    	$sql = 'SELECT *
    			FROM table2
    			INNER JOIN table1
    			ON table2.NumNews = table1.id';
     
    	$req = mysql_query($sql) or die('Erreur SQL !<br>'.$sql.'<br>'.mysql_error()); 
     
    	$old=null;		
     
    	while ($data = mysql_fetch_assoc($req)) {
     
    	if ($old === null) {
     
    	$old = $data['NumNews'];
    ?>	
     
    <div class="news">
    	<div class="info_news">
    		<?php
    			echo $data['Date'];
    			echo $data['TitreNews'];
    			echo $data['TexteNews'];
    			echo $data['SousTitre'];
    		?>
    	</div>
     
    	<div class="diaporama_news">	   
    		<ul id="Gallery<?php echo $data['NumNews']?>">Galery <?php echo $data['NumNews']?>
    			<?php 
    				}
    				if($old != $data['id']){
    			?>
    		</ul>
    	</div>
    </div>
     
    <div class="news">
    	<div class="info_news">
    		<?php
    			echo $data['Date'];
    			echo $data['TitreNews'];
    			echo $data['TexteNews'];
    			echo $data['SousTitre'];
    		?>
    	</div>
     
    	<div class="diaporama_news">
    		<ul id="Gallery<?php echo $data['NumNews']?>">Galery <?php echo $data['NumNews']?>
     
    			<?php
    				}
    			?>
     
    			<li><?php echo $data['PhotoMax']?><?php echo $data['PhotoMin']?><?php echo $data['Titre']?></li>
     
     
    			<?php
    				}
    			?>					
    		</ul>               
    	</div>       
    </div>
     
    <?php
    	mysql_close();
    ?>

    et enfin le résultat que j’obtiens :



    La galerie 1 fonctionne parfaitement, mais la galerie deux bug en se divisant.

    Quelqu'un pourrait-il me guider pour que ça fonctionne.
    Est-ce un problème de césure mal placée dans la boucle ?
    Manque t'il une condition à un endroit ?

    Je remercie d'avance toutes personnes qui pourront me venir en aide pour que je puisse progresser et avancer sur mon projet.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Difficile de s'y retrouver dans ton code, où tu imbriques plusieurs conditions...
    Vérifie toutes les accolades, explique le rôle de $old, et mets des commentaires.

  3. #3
    Nouveau candidat au Club
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Webdesigner
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2012
    Messages : 2
    Par défaut
    J'ai réussi à faire fonctionner le script.

    Pour ceux que ça intéresse, il faut ajouter "&& $old = $data['NumNews']" dans le deuxième if.

    Effectivement mon code est un peu chaotique, je m'en excuse, n'étant pas encore trop familiarisé avec php/mysql et les forum dédié.

    Je serais beaucoup plus clair à mon prochain post

  4. #4
    Invité
    Invité(e)
    Par défaut
    Mettre des commentaires dans ton code est important :
    - si tu veux pouvoir le reprendre (et le comprendre !) quelques mois ou années plus tard...
    - ou pour le transmettre à un autre développeur.

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

Discussions similaires

  1. [MySQL] bug dans une boucle for
    Par skyarnangel dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 11/05/2010, 14h08
  2. Récupérer les coordonnées de plusieurs DIV dans une boucle PHP
    Par renaud26 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 05/11/2009, 10h23
  3. [MySQL] Requetes SQL dans une boucle PHP
    Par Siteac dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 12/11/2006, 14h35
  4. [Smarty] Affectation dans une boucle PHP
    Par Invité dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 22/08/2006, 09h30
  5. [Performance] LEFT JOIN vs SELECT dans une boucle (PHP)
    Par frochard dans le forum Requêtes
    Réponses: 4
    Dernier message: 28/10/2005, 17h45

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