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

Bibliothèques et frameworks PHP Discussion :

Comment faire une recherche avec deux mots dans une table


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 096
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 096
    Points : 944
    Points
    944
    Par défaut Comment faire une recherche avec deux mots dans une table
    Bonjour à tous,

    Je dois faire un recherche des mes champs content et name.
    Ce code fonctionne avec un mot
    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
     
    	$search = $this->request->data['Search']['key'];
    $this->loadModel('Page');
    		$d['pages'] = $this->Page->find('all', array(
            	'conditions' => array(
            		'online'=>'1',
            		'type'=>'page',
            		'created <= NOW()',
            		'id > 1',
            		'OR' => array(
            			'Page.name LIKE'=>'%'.$search.'%',
            			'Page.content LIKE'=>'%'.$search.'%'
            			)
            		),
            	'fields'=> array('name','content','created','id','type')
           	));
    Si dans la variabel $search, il y a le mot "web", il va me retourner toutes les enregistrements contenant ce mot.

    Mais si je mets "web design" ou "web internet" ou web travail dormir"

    Il me retiurne rien du tout.

    Je n'ai aucune idée comment faire qu'il considere comme deux critère de recherche

    Avez vous une idée
    Il ne suffit pas de tout savoir. Vouloir et persévérer, c'est déjà presque tout!

  2. #2
    Membre éprouvé Avatar de Shuty
    Homme Profil pro
    Ingénieur en développement
    Inscrit en
    Octobre 2012
    Messages
    630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur en développement
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2012
    Messages : 630
    Points : 1 174
    Points
    1 174
    Par défaut
    Je ne connais pas du tout cakePhP mais orientes toi vers les clauses like.

    http://stackoverflow.com/questions/3...-cakephp-mysql
    Agence web Dim'Solution, créateur de solutions numériques
    Sites internet, ecommerce, logiciels, applications mobiles, référencement (SEO), plugin Prestashop, Magento, WordPress, Joomla!...

    Cours de trading gratuit | Envoyer des sms gratuitement | Envoyer des fax gratuitement | Plateforme de Fax à l'international

  3. #3
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Hello !

    Il y a une erreur dans l'écriture de ta clause 'OR'.

    Voici la syntaxe correcte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    	'OR' => array(
            		array('Page.name LIKE'=>'%'.$search.'%'),
            		array('Page.content LIKE'=>'%'.$search.'%')
            	)
    La doc : http://book.cakephp.org/2.0/fr/model...rche-complexes

    Ca devrait passer maintenant
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

Discussions similaires

  1. Réponses: 6
    Dernier message: 24/05/2014, 12h38
  2. Formule Si avec recherche d'un mot dans une ligne
    Par maximus30 dans le forum Excel
    Réponses: 2
    Dernier message: 06/12/2012, 18h20
  3. Réponses: 4
    Dernier message: 15/04/2011, 17h13
  4. faire une recherche avec plusieurs mot-clés
    Par jakouz dans le forum Débuter
    Réponses: 2
    Dernier message: 16/12/2010, 13h50
  5. Faire la recherche d'un élement dans une colonne avec la fonction match
    Par ckrikri dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 24/11/2008, 11h54

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