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 :

Traiter le résultat d'une requête ne retournant pas des entités


Sujet :

ORM PHP

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut Traiter le résultat d'une requête ne retournant pas des entités
    Bonjour,

    Dans mon repository, dans la fonction "findByProximityQuery', je renvoie les annonces (chacune liée à un véhicule lui-même lié à une adresse) triées par ordre croissant de distance par rapport à une latitude et une longitude données. En plus des annonces, je renvoie également la distance elle-même afin de pouvoir l'afficher.

    Mon problème, c'est que comme j'ajoute la distance dans mon select, le résultat de la requête n'est plus une collection d'annonces.

    Voici la partie du code de ma fonction dans laquelle j'ajoute la distance à mon select :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
     
    ...
            $query = $this->createQueryBuilder('a')
                          ->distinct(true)
                          ->join('a.vehicle', 'v')
            ;
     
            if ($search->getLatitude() && $search->getLongitude()) 
            {
                $sqlDistance = '(6353 * 2 * ASIN(SQRT( POWER(SIN((s.latitude - :latitude) *  pi()/180 / 2), 2) +COS(s.latitude * pi()/180) * COS(:latitude * pi()/180)' . 
                               ' * POWER(SIN((s.longitude - :longitude) * pi()/180 / 2), 2) ))) as distance';
     
                $query
                    ->addSelect($sqlDistance)
                    ->join('v.situation', 's') //Ici, c'est l'adresse qui contient la latitude et la longitude
                    ->orderBy('distance', 'ASC')
                    ->setParameter('longitude', $search->getLongitude())
                    ->setParameter('latitude', $search->getLatitude())
                ;
    ...
    return $query->getQuery();
    ...
    Or, dans la suite de mon traitement, j'affiche les différentes annonces en utilisant des propriétés et des méthodes de l'entité "Advert". Cependant, à cause du addSelect($sqlDistance), ce n'est plus une collection d'annonces qui m'est retournée.

    Dès lors, je ne sais pas comment soit modifier ma requête, soit comment traiter le résultat de ceci pour travailler avec des objets de type "Advert".

    Quelqu'un aurait une idée?

    Merci d'avance pour votre aide.

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    J'ai réussi à obtenir ce que je cherchais en procédant de cette manière :

    Dans mon repository, je renvoie le résultat comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
            return $query->getQuery()
                         ->getResult();
    Dans mon controller, je le traite de cette manière :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
            $results = $this->advertRepository->findByProximityQuery($search);
     
            foreach ($results as $result) 
            {
     
                $adverts[] = $result[0];
     
                $advertId = $result[0]->getId();
     
                $distances[$advertId] = round($result["distance"], 2);
     
            }
    Cependant, je me demande s'il n'y a pas une manière plus performante de travailler...

Discussions similaires

  1. [AJAX] Traiter le résultat d'une requête SQL avec jQuery
    Par Aizen64 dans le forum jQuery
    Réponses: 2
    Dernier message: 09/11/2015, 08h27
  2. [AJAX] Traiter le résultat d'une requête en AJAX
    Par Marmotton76 dans le forum AJAX
    Réponses: 12
    Dernier message: 18/08/2011, 13h27
  3. [AC-2003] Vérifier que le résultat d'une requête (n')est (pas) vide
    Par pedrus16 dans le forum VBA Access
    Réponses: 3
    Dernier message: 25/06/2009, 15h34
  4. Réponses: 34
    Dernier message: 24/05/2007, 16h19
  5. Réponses: 4
    Dernier message: 26/05/2006, 08h59

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