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

Requêtes MySQL Discussion :

[like][index] utiliser <colonne> like 'foo%'


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de hansaplast
    Homme Profil pro
    Artisant logiciel
    Inscrit en
    Septembre 2005
    Messages
    951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Artisant logiciel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 951
    Par défaut [like][index] utiliser <colonne> like 'foo%'
    Bonjour,

    Je cherche a retrouver, a partir d'un string, une valeur en base de donnée.
    jusque là, rien de special.
    Là ou ca se complique, c'est qu'en realitée la valeur en base de donnée doit pouvoir posseder des wilCards.
    je m'explique :


    la table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE TABLE `route` (                    
              `route` varchar(150) NOT NULL,          
              `module` varchar(100) default NULL,     
              `controler` varchar(100) default NULL,  
              `action` varchar(100) default NULL,     
              `lang` varchar(2) default NULL,         
              PRIMARY KEY  (`route`)                  
            ) ENGINE=InnoDB DEFAULT CHARSET=latin1
    la requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select route, module, controler, `action` from zf_route where 'foo.bar' like route
    le resultat :
    route module controler action lang
    ------ ------ --------- ------ ------
    foo.% (NULL) index index fr
    Bonne nouvelle : ca marche!
    mauvaise nouvelle : ca n'utilise pas les index :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    explain select * from route where 'foo.bar' like route;
    id select_type table type possible_keys key key_len ref rows Extra
    ------ ----------- ------ ------ ------------- ------ ------- ------ ------ -----------
    1 SIMPLE route ALL (NULL) (NULL) (NULL) (NULL) 1 Using where
    Donc, ma question est : avez vous une idée d'une facon de faire propre (utiliser un like de facon inversée me semble aberrant, mais, j'ai aps d'autre idée) et / ou de comment faire en sorte que des index soient utilisés.

    J'ai essayé aussi en mettant un index full text sur la colonne incriminée, sans succes.

    .

  2. #2
    Membre éprouvé Avatar de hansaplast
    Homme Profil pro
    Artisant logiciel
    Inscrit en
    Septembre 2005
    Messages
    951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Artisant logiciel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 951
    Par défaut
    j'ai enfin trouvé dans la doc :

    Les commandes SELECT suivantes n'utilisent pas d'index :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    mysql> SELECT * FROM tbl_name WHERE key_col LIKE "%Patrick%";
    mysql> SELECT * FROM tbl_name WHERE key_col LIKE other_col;
    Dans la première requête, la valeur associée à LIKE commence avec un caractère joker. Dans le second exemple, la valeur associée à LIKE n'est pas une valeur constante.
    l'utilisation d'index n'est donc pas possible :'(

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

Discussions similaires

  1. Index impossible pour une clause LIKE '%ABC%' ?
    Par Plageman dans le forum Firebird
    Réponses: 2
    Dernier message: 14/10/2010, 18h47
  2. [MySQL] requete sql avec like en utilisant une variable
    Par amesnaou dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 27/05/2009, 10h22
  3. Utilisation de variable dans LIKE
    Par pracede2005 dans le forum Développement
    Réponses: 3
    Dernier message: 25/10/2008, 00h48
  4. Réponses: 2
    Dernier message: 30/11/2007, 13h55
  5. Réponses: 1
    Dernier message: 01/03/2005, 21h36

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