Prob avec les boucle While (PHP)

Fermé
Percherie - 21 août 2003 à 17:16
 percherie - 21 août 2003 à 19:51
Bonjour je debute et je seche sur un drole de problème

Sur une page j'utilise 2 boucle while a deux endroit et pour deux raisons bien distincte

Si la première (dans l'ordre de lecture de la page) s'execute la seconde ne fonctionne plus... si je désactive la premiere comme par enchantement la seconde fonctionne

Je pense qu'il faut fermer les boucles proprement mais je vois pas du tout comment faire... franchement c bizarre

J'attend vos réponses, merci
A voir également:

5 réponses

Utilisateur anonyme
21 août 2003 à 17:19
Salut,
Ben heu, c'est un peu obscure comme ca... Montre ton code, qu'on puisse jeter un coup d'oeil.
Tu dois avoir une erreur quelque part. :)

Kalamit,
Parle à ma culasse, mon carter est malade. :)
0
Donc voici le code en question


//ici je récupère dans la variable $diapos une partie d'un tableau Mysql

if($page != ''){
$requete = "SELECT * FROM diapos WHERE page='$page' ORDER BY position ASC";
$diapos = mysql_query ($requete,$db);
}


//Là c'est la premiere boucle while qui marche trés bien

while ($donne = mysql_fetch_object($diapos))
{
print ("$donne->img1\, $donne->img2, $donne->url");
}


//Et pour finir la boucle qui ne fonctionnne qu'en desactivant la premiere

while ($donnee = mysql_fetch_object($diapos))
{
print ("test = $donnee->nom retest = $donnee->url");
}


Voilà je seche... mais la seul solution que j'ai trouvé c'est fermer par une fonction ces boucle mais là c'est un truc que je connait pas encore
0
la fonction mysql_fetch_object recupere une ligne de ta requete
la boucle s'arrete quand tu as tout extrait

si apres tu refais un mysql_fetch_object il ne feras plus rien car tu as tout extrait
Essaye ca:

if($page != ''){
$requete = "SELECT * FROM diapos WHERE page='$page' ORDER BY position ASC";
$diapos = mysql_query ($requete,$db);
}

while ($donne = mysql_fetch_object($diapos))
{
print ("$donne->img1\, $donne->img2, $donne->url");
}


if($page != ''){
$diapos2 = mysql_query ($requete,$db);
}

while ($donnee = mysql_fetch_object($diapos2))
{
print ("test = $donnee->nom retest = $donnee->url");
}
0
Utilisateur anonyme
21 août 2003 à 18:22
Ju66 a raison.
A mon avis, tu n'utilises pas la bonne fonction pour récuperer tes données. En faisant comme ca, tu va etre obligé d'executer deux fois la meme requete. Pas très optimisé... :/

Kalamit,
Parle à ma culasse, mon carter est malade. :)
0
PhP Messages postés 1770 Date d'inscription lundi 11 décembre 2000 Statut Membre Dernière intervention 23 décembre 2009 606
21 août 2003 à 19:24
Bsr Percherie

En effet à l'issue de ta 1ère boucle le pointeur interne est positionné à la fin du jeu d'enregistrements retournés par ta requête sql.
Autrement dit dès que tu éxécutes de nouveau mysql_fetch_object() au début de la seconde boucle le résultat retourné est FALSE : la boucle se termine aussitôt.

L'astuce : replacer le pointeur au départ, tout simplement !
En plus ca t'évite de réexécuter la même requête : simplification & optimisation que demander de plus.

Et la syntaxe est :
bool mysql_data_seek ( resource result_identifier, int row_number)

Donc avant ta seconde boucle tu mets :

mysql_data_seek($diapos,0);


Et ca roule ... ;-)

@+

PhP    [Push the button,Don't push the
.         button,Trip the station,Change the channel]
0
Ok j'avais penssai a ça aussi mais j'etait pas remonter aussi loin dans cette logique

Comme la toute premiere partie du code ce trouve avec les parametre de connection a la base je vais essayé ceci :

$requete = "SELECT * FROM diapos WHERE page='$page' ORDER BY position ASC";
$diapos = mysql_query ($requete,$db);
$diapos2 = mysql_query ($requete,$db);


Perso en debut d'aprés midi j'avais tenter ceci : $diapos2 = $diapos mais sans succés... a moins qu'il fallait repeter la requete depuis le debut

Enfin quoi qu'il en soit je vais tester ça cette nuit (faut s'occuper des gosses là) et je vous tient au courant
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Je confirme, ça marche... je viens tous juste d'essayer... merci les gens
0