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 :

Foreach qui "tourne trop"


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Février 2016
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 47
    Points : 25
    Points
    25
    Par défaut Foreach qui "tourne trop"
    Bonjour,

    J'ai fait un foreach qui ne devrait tourner qu'une seule fois pour mon test, mais il tourne deux fois. Je ne comprends pas pourquoi.

    Ma premiere requete SQL me retourne une seule valeur, et mon foreach tourne selon le nombre de valeur que me retourne la requete. Alors pourquoi le foreach s'execute deux fois ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    $contenu1=$bdd1->query("SELECT  node_field_data.title from node__body, node_field_data, node WHERE node.nid=node__body.entity_id AND node_field_data.nid=node.nid");
     
    $resul=$contenu1->fetch();
    foreach($resul as $row){
     
    $titre = $resul['title'];
    	$cor1=$bdd1->query("SELECT node__body.body_value FROM node__body,node, node_field_data WHERE node.nid=node__body.entity_id AND node_field_data.nid=node.nid AND node_field_data.title='".$titre."'");
    	$cor=$bdd2->query("SELECT node__body.body_value from node__body, node, node_field_data WHERE node.nid=node__body.entity_id AND node_field_data.nid=node.nid AND node_field_data.title='".$titre."'");
    $corr=$cor->fetch();
    $corr1=$cor1->fetch();
    print_r($corr['body_value']);
    print_r($corr1['body_value']);
    }
    Une idée ?

  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
    Par "il tourne deux fois", tu veux qu'il est exécuté deux fois ou une seule fois, mais avec deux éléments ?
    Tu as débuggé avec un var_dump de $res ? des affichages de compteurs ?
    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
    Nouveau membre du Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Février 2016
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 47
    Points : 25
    Points
    25
    Par défaut Re
    J'entends par la qu'il est executé deux fois (au lieu d'une puisque j'ai qu'une valeur qui sort de ma requete de base). Je n'ai pas utilisé de var dump ou quoi, j'ai juste lmis mes deux print_r qui devraient m'afficher deux chaines de caracteres une seule fois, mais la ca me retourne 2 fois les 2 chaines

  4. #4
    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
    En relisant bien le code, je viens de voir un truc bizarre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $resul=$contenu1->fetch();
    foreach($resul as $row){
        $titre = $resul['title'];
    Si tu utilises fetch, tu ne récupères que la 1ere ligne de résultat. Donc boucler $resul revient à boucler sur les colonnes de cette ligne de résultat.
    Ensuite, tu n'exploites pas $row à l'intérieur du foreach mais tu travailles directement avec $resul.

    A mon avis, c'est soit fetch et pas de foreach :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $resul=$contenu1->fetch();
    $titre = $resul['title'];
    soit fetchAll et tu utilises $row à l'intérieur du foreach :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $resul=$contenu1->fetchAll();
    foreach($resul as $row){
      $titre = $row['title'];
    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]

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Février 2016
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 47
    Points : 25
    Points
    25
    Par défaut Re
    Mais oui !!

    J'avais beau relire mon code depuis 1heure je n'avais pas vu que je n'utilisais pas mon $row, et effectivement en modifiant cette erreur et en utilisant fetchAll j'obtiens bien le résultat attendu.

    Merci de m'avoir débloqué.

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

Discussions similaires

  1. Update qui dure beaucoup trop de temps
    Par hoaxpunk dans le forum Oracle
    Réponses: 12
    Dernier message: 04/05/2006, 23h29

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