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 :

Recherche avec multicritères , methode GET [2.x]


Sujet :

Symfony PHP

  1. #1
    Membre régulier
    Inscrit en
    Octobre 2008
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 128
    Points : 79
    Points
    79
    Par défaut Recherche avec multicritères , methode GET
    Salut,

    J'ai crée un code pour faire un recherche avec multicritères mais il marche seulement si tous les champs sont remplis dans le formulaire et si un champ est vide , la requête n'affiche rien. Comment je peux faire un "where" seulement sur les champs non vide ? merci d'avance

    Controller:
    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
    23
    24
    25
    26
    27
    28
     
    public function listSearchAction($page, Request $request)
     {
     
         if ($request->getMethod() == 'GET') {
     
         $em = $this->getDoctrine()->getManager();
     
         $paginator  = $this->get('knp_paginator');
     
     
         $name = $request->query->get('name');
         $city = $request->query->get('city');
     
         $qb = $em->getRepository('ProjectAgenceBundle:Agence')->getListSearchAgencesFrontend($name, $city);  
     
         $pagination = $paginator->paginate(
         $qb,
         $request->query->get('page', $page),10);
     
         }
     
     
         return $this->render('ProjectFrontendBundle:Agence:agence-search-list-view.html.twig',array(
         'pagination' => $pagination,
         'mode'=> $mode,
         ));
     }
    Repository
    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
     
    public function getListSearchAgencesFrontend($name, $city)
    {
        $qb = $this->createQueryBuilder('a')
            ->leftJoin('a.logo', 'l')
            ->addSelect('l')
            ->Where('a.enabled = 1')
            ->andWhere('a.city = :city')
            ->setParameter('city', $city)
            ->andWhere('a.name LIKE :name')
            ->setParameter('name', '%'.$name.'%');
     
        return $qb;
     
    }
    from.twig
    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
     
    <form action="{{ path('frontend_agences_list_search') }}" method="get">
               <div class="form-group">
                   <label>Nom agence</label>
                   {{ form_widget(left_form_search.name) }}
               </div>
     
               <div class="form-group">
                   <label>Ville</label>
                     <div class="selector">
                       {{ form_widget(left_form_search.city) }}
                    </div>
               </div>
               {{ form_rest(left_form_search) }}
               <br />
              <button type="submit" class="btn-medium icon-check uppercase full-width">recherche</button>
       </form>

  2. #2
    Membre régulier
    Inscrit en
    Octobre 2008
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 128
    Points : 79
    Points
    79
    Par défaut
    Résolu

    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
     
     
    	public function getListSearchAgencesFrontend($name = NULL, $city = NULL)
    	{
        	$qb = $this->createQueryBuilder('a')
    			->leftJoin('a.logo', 'l')
    			->addSelect('l')
    			->Where('a.enabled = 1');
     
    	if (!empty($city) ) {
            $qb->andWhere('a.city = :city')
            ->setParameter('city', $city);
        	}
        	if (!empty($name)) {
            	$qb->andWhere('a.name LIKE :name')
                   ->setParameter('name', '%'.$name.'%');
        	}
     
    	 return $qb;
     
    	}

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 04/01/2010, 21h07
  2. [cURL] Envoyer des données avec la methode GET
    Par hicham285 dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 21/11/2007, 16h46
  3. Problème avec la method Get
    Par Mat67 dans le forum Langage
    Réponses: 10
    Dernier message: 25/06/2007, 12h13
  4. Réponses: 5
    Dernier message: 11/09/2005, 12h17
  5. probleme avec methode get
    Par Tr@nkill dans le forum ASP
    Réponses: 2
    Dernier message: 12/05/2005, 13h54

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