Téléchargement
illégal
Posez votre question Signaler

Prob avec les boucle While (PHP)

Percherie - Dernière réponse le 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
Lire la suite 

Prob avec les boucle While (PHP) »

7 réponses
Réponse
+0
moins plus
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. :)
Ajouter un commentaire
Réponse
+0
moins plus
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
ju66 - 21 août 2003 à 18:12
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");
}
kalamit- 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. :)
Ajouter un commentaire
Réponse
+0
moins plus
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]
Ajouter un commentaire
Réponse
+0
moins plus
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
Ajouter un commentaire
Réponse
+0
moins plus
Je confirme, ça marche... je viens tous juste d'essayer... merci les gens
Ajouter un commentaire
Ce document intitulé « Prob avec les boucle While (PHP) » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?