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

ORM PHP Discussion :

problème avec fetchArray [Doctrine]


Sujet :

ORM PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut problème avec fetchArray
    Bonjour, j'utilise doctrine depuis peu (version 1.2)

    je fais une requete et je souhaite afficher les resultats, donc quelque chose d'assez simple. Cependant je bloque sur une requete qui m'affiche que 1 resultat au lieu de 25. voici le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     $q = Doctrine_Query::create()
    	->select('campaign_name as name, SUM( ads_nb_clicks ) AS click, (SUM( ads_nb_display ) + SUM( ads_social_display )) AS prints, ads_max_bid AS cpc, (SUM( ads_spent ) + SUM( ads_social_spent )
    ) AS spent, (SUM( ads_nb_clicks ) / (SUM( ads_spent ) + SUM( ads_social_spent )
    )) as ctr')
        ->from('campaign AS c, ads AS a, AdsStats AS ast, AdsGroup AS ag ')
        ->where('c.agency_agency_id = ?', $idAgence)
    	->andWhere('campaign_id = ag.campaign_campaign_id')
    	->andWhere('ag.ads_group_id = a.ads_group_ads_group_id')
    	->andWhere('ast.ads_ads_id = ads_id')
    	->groupBy('campaign_name')
    	->orderBy('spent DESC')
    	;
    $this->topCampagne = $q->fetchArray();

    ensuite j'affiche les résultats avec un foreach
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <?php 
    foreach ($topCampagne as $top)
    {
    ?>
    <tr>
    <td><?php echo $top['name'] ?></td>
    <td><?php echo $top['click']?></td>
    <td><?php echo $top['prints'] ?></td>
    <td><?php echo $top['ctr'] ?></td>
    <td><?php echo $top['cpc'] ?></td>
    <td><?php echo $top['spent'] ?></td>
    </tr>
    <?php } ?>

    et je n'ai que un seul résultat alors que la fonction $q->count() retoune 25 ????
    je dois donc avec 25 resultats.... je ne comprend pas pourquoi je n'ai qu'un seul resultat......

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Par défaut
    et juste execute ca marche ?

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut
    bonjour stealth35 execute() renvoie exactement la même chose.
    j'ai testé la requete sous phpmyadmin elle fonctionne parfaitement mais avec doctrine...

  4. #4
    Membre expérimenté Avatar de Stopher
    Homme Profil pro
    Responsable technique
    Inscrit en
    Juin 2004
    Messages
    198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Responsable technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2004
    Messages : 198
    Par défaut
    Salut ,

    C'est juste une faute de frappe ou juste une modif qui intervient entre deux ?

    tu enregistres les résultats dans l'attribut

    Et tu fais un foreach de


    Sinon , un var_dump($this->topCampagne) te retourne quoi ?
    Ch.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut
    Bonsoir stopher pour le code
    c'est parce que j'utilise symfony donc ensuite dans le template je récupère les données comme cela
    pour le vardump il m'affiche ceci.

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    array(1) { [0]=> array(6) { ["name"]=> string(3) "mcd" ["click"]=> string(1) "0" ["prints"]=> string(1) "0" ["cpc"]=> string(2) "40" ["spent"]=> string(2) "66" ["ctr"]=> string(6) "0.0000" } }

  6. #6
    Expert confirmé
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Par défaut
    Dans symfony, dans la barre de debug, dans l'option à plus à droite, tu peux récupérer les requêtes sql générée.

    Est-ce ce celle que tu espères avoir créé ?

    Pourquoi ne pas utiliser les liens créés dans le shema dans ta requête mais redéfinir les liaisons ?

    Essaye avec execute dans un premier temps. Ensuite, quant on aura compris pourquoi il ne veut pas envoyer tous les enregistrements, on pourra hydrater en tableau directement depuis execute().

    Dans le select, précise l'allias de la table pour chaque champ.

    A la réflexion, essaye execute avec un HYDRATE_SINGLE_SCALAR pour l'hydratation, tu devrais avoir un tableau plat. Plus d'information sur l'hydratation avec doctrine ici, même si je pense que tu l'as déjà lu .

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    52
    Détails du profil
    Informations personnelles :
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Juin 2006
    Messages : 52
    Par défaut
    Merci Michel pour l'aide que tu m'apportes.
    Dans symfony, dans la barre de debug, dans l'option à plus à droite, tu peux récupérer les requêtes sql générée.
    Est-ce ce celle que tu espères avoir créé ?
    La requête générée est effectivement celle que je veux je l'ai testé sous phpmyadmin elle fonctionne.
    J'ai essayer avec execute et un HYDRATE_SINGLE_SCALAR j'obtiens effectivement un tableau plat avec l'ensemble des noms que me renvoi la requete mais je n'arrive pas à récupérer les autres résultats. J'essaie de voir si une autre méthode d'hydratation pourrait m'aider.

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

Discussions similaires

  1. VC++ Direct3D8, problème avec LPD3DXFONT et LPD3DTEXTURE8
    Par Magus (Dave) dans le forum DirectX
    Réponses: 3
    Dernier message: 03/08/2002, 11h10
  2. Problème avec [b]struct[/b]
    Par Bouziane Abderraouf dans le forum CORBA
    Réponses: 2
    Dernier message: 17/07/2002, 10h25
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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