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

ADO.NET Discussion :

BindingSource.Filter LIKE sur chaine avec %


Sujet :

ADO.NET

  1. #1
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut BindingSource.Filter LIKE sur chaine avec %
    Bonjour,

    Quand j'utilise la propriété Filter d'un BindingSource avec une clause LIKE, pour trouver tous les enregistrements dont le champ "MON_CHAMP_TEXTE" contient la lettre "Z", j'écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    MonBindingSource.Filter = "MON_CHAMP_TEXTE LIKE '%Z%'" ;
    Que faut-il faire pour trouver les enregistrement qui contiennent le caractère "%"?
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  2. #2
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    J'ai l'impression qu'on peut faire ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    MonBindingSource.Filter = "MON_CHAMP_TEXTE LIKE '%" +
       Ma_string_Cherchee.Replace("!","!!").Replace("'","!'")    +
       "'%' escape '!'" ;
    Ce qui pour Ma_string_Cherchee = "%" donnerait :
    MON_CHAMP_TEXTE LIKE '%!%%' escape '!'

    Quelqu'un pourrait confirmer ?
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par Graffito Voir le message
    Quelqu'un pourrait confirmer ?
    Ben si ça marche, ça confirme que c'est ça, non ?

    Bon à savoir en tous cas

    EDIT: apparement tu peux mettre le caractère spécial entre crochets:

    "MON_CHAMP_TEXTE LIKE '%[%]%'"

    Cette recherche Google donne pas mal de résultats

  4. #4
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    Ben si ça marche, ça confirme que c'est ça, non ?
    Je voulais juste savoir si il n'y avait pas des cas où ça ne marcherait pas.

    Et tu en as justement donné un :
    mettre le caractère spécial entre crochets : "MON_CHAMP_TEXTE LIKE '%[%]%'"
    Donc, il faut 2 Replace de plus :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    MonBindingSource.Filter = "MON_CHAMP_TEXTE LIKE '%" +
       Ma_string_Cherchee.Replace("!","!!").Replace("'","!'").
                         Replace("[","!'[").Replace("]","!]").      +
       "'%' escape '!'" ;
    Je teste...
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par Graffito Voir le message
    Je voulais juste savoir si il n'y avait pas des cas où ça ne marcherait pas.

    Et tu en as justement donné un :


    Donc, il faut 2 Replace de plus :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    MonBindingSource.Filter = "MON_CHAMP_TEXTE LIKE '%" +
       Ma_string_Cherchee.Replace("!","!!").Replace("'","!'").
                         Replace("[","!'[").Replace("]","!]").      +
       "'%' escape '!'" ;
    Je teste...
    hein ?
    Si tu utilises les crochets tu n'as plus besoin du "escape '!'" a priori...

  6. #6
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    Finalement, le ESCAPE ne fonctionne pas.


    Donc, pour des valeurs chaines à comparer :
    1. quelque soit l'opérateur de comparaison (= , > , < , LIKE, IN, ...), on remplace toute quote par 2 quotes,
    2. pour un operateur LIKE, on remplace dans la chaine :
    . "%" par "[%]",
    . "[" par "[[]",
    . "]" par "[]]".

    Merci, tomlev pour ta contribution .
    " Le croquemitaine ! Aaaaaah ! Où ça ? " ©Homer Simpson

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

Discussions similaires

  1. Probleme sur requete avec LIKE
    Par cryosore dans le forum JDBC
    Réponses: 13
    Dernier message: 23/04/2009, 14h23
  2. Requete avec LIKE sur du texte avec des slash
    Par mkaffel dans le forum Requêtes
    Réponses: 4
    Dernier message: 18/12/2007, 12h07
  3. recherche d'une chaine avec Like
    Par pierre2410 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 25/05/2007, 11h37
  4. [SQL2K]Requete sur une chaine avec une ou plusieurs quote
    Par tazamorte dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 17/04/2007, 08h22
  5. Recherche d'un mot avec LIKE sur plusieurs champs
    Par reynhart dans le forum Langage SQL
    Réponses: 16
    Dernier message: 26/11/2004, 17h41

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