Rechercher : dans
Par :

Prob avec les boucle While (PHP)

Dernière réponse le 21 aoû 2003 à 19:51:46 Percherie, le 21 aoû 2003 à 17:16:15 
 Signaler ce message aux modérateurs

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

Meilleures réponses pour « Prob avec les boucle While (PHP) » dans :
Comment lire un fichier ligne par ligne VoirComment lire un fichier ligne par ligne Préambule Boucle while Syntaxe Exemple Astuces Bonus Boucle for Syntaxe Préambule Une des erreurs les plus communes dans l'apprentissage des scripts "bash" sous GNU/LInux pour lire un fichier...
PHP - Bases de données VoirPhp permet un interfaçage très simple avec un grand nombre de bases de données. Lorsqu'une base de données n'est pas directement supportée par Php, il est possible d'utiliser un driver ODBC, pilote standard pour communiquer avec les bases de...
Java: Les structures conditionnelles VoirQu'est-ce qu'une structure conditionnelle? On appelle structure conditonnelle les instructions qui permettent de tester si une condition est vraie ou non. Ces structures conditionnelles peuvent être associées à des structures qui se répètent...
Javascript - Les structures conditionnelles VoirQu'est-ce qu'une structure conditionnelle? On appelle structure conditonnelle les instructions qui permettent de tester si une condition est vraie ou non, ce qui permet notamment de donner de l'interactivité à vos scripts. L'instruction...

1

kalamit, le 21 aoû 2003 à 17:19:56

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. :)

Répondre à kalamit

2

percherie, le 21 aoû 2003 à 17:27:55

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

Répondre à percherie

3

ju66, le 21 aoû 2003 à 18:12:49

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");
}

Répondre à ju66

4

kalamit, le 21 aoû 2003 à 18:22:18

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. :)

Répondre à kalamit

5

PhP, le 21 aoû 2003 à 19:24:58

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]

Répondre à PhP

6

percherie, le 21 aoû 2003 à 19:28:12

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

Répondre à percherie

7

 percherie, le 21 aoû 2003 à 19:51:46

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

Répondre à percherie