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

Symfony PHP Discussion :

Doctrine where OR [2.x]


Sujet :

Symfony PHP

  1. #1
    Membre habitué Avatar de Echyzen
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2012
    Messages
    123
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 123
    Points : 178
    Points
    178
    Par défaut Doctrine where OR
    Salut à tous,

    Voilà j'ai un soucis je cherche a faire comme ne SQL une suite de condition OR...

    J'ai donc fais cela :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    foreach ($genreId as $value) {
    	$requete = $requete->orWhere('g.id = :id')->setParameter('id', $value);
    }
    Le problème c'est que cela revient a faire un where avec la dernier valeur du tableau $genreId je comprends pas pourquoi il ne me fais pas le 'OU'.
    C'est quand même fou que cela soit aussi compliqué de faire une requete aussi simple XD

    Si quelqu'un peut me dépanner?

    Merci d'avance de vos réponses

  2. #2
    Membre expérimenté Avatar de Nico_F
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2011
    Messages
    728
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2011
    Messages : 728
    Points : 1 310
    Points
    1 310
    Par défaut
    Salut,

    Tu utilises systématiquement la même clé ('id') quand tu fais ton setParameter, donc cette clé est écrasée à chaque passage dans la boucle et ne possède qu'une seule valeur : la dernière.
    Pour que ta boucle fonctionne il faudrait que tu aies une clé différente à chaque fois par exemple en incrémentant un compteur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $i=1;
    foreach ($genreId as $value) {
    	$requete = $requete->orWhere('g.id = :id'.$i)->setParameter('id'.$i, $value);
            $i++;
    }
    De cette manière, tous tes id seront pris en compte.

    C'est quand même fou que cela soit aussi compliqué de faire une requete aussi simple
    C'est quand même fou que tu rendes la requête aussi compliquée avec une succession de orWhere, alors que tu pourrais utiliser un where in et virer le foreach.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $requete->orWhere('g.id IN (:genreId)')->setParameter('genreId', $genreId);
    ++

  3. #3
    Membre habitué Avatar de Echyzen
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2012
    Messages
    123
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2012
    Messages : 123
    Points : 178
    Points
    178
    Par défaut
    Bah merci pour tout c'est clair nette est précis
    (et oui je suis une buse XD)

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

Discussions similaires

  1. [COUNT] select ... from ... where count !
    Par tmcgrady dans le forum Langage SQL
    Réponses: 5
    Dernier message: 30/11/2007, 17h29
  2. question sur SELECT ...WHERE...IN
    Par danseur dans le forum Requêtes
    Réponses: 3
    Dernier message: 23/01/2004, 15h23
  3. Select * Where {}
    Par Thomad dans le forum Langage SQL
    Réponses: 14
    Dernier message: 16/10/2003, 21h27
  4. "where @text" ou @text='nom='julien'' fonctionne p
    Par lord_paco dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 08/09/2003, 14h37
  5. where sur la première colonne
    Par r-zo dans le forum Requêtes
    Réponses: 8
    Dernier message: 28/07/2003, 09h55

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