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

VB.NET Discussion :

Utilisation du mot LIKE dans une requete


Sujet :

VB.NET

  1. #1
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 17
    Points
    17
    Par défaut Utilisation du mot LIKE dans une requete
    Bonjour,

    Je fais une requete dans laquelle je me sert du mot Like. Voici mon code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    dim requete as string
     
    requete = " select DOSSIER,GENRE from DOSSIER WHERE GENRE LIKE  '[Vv]%' ORDER BY DOSSIER"
    le resultat de ma requete est null

    j'ai meme essayer ce code la aussi:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    dim requete as string
     
    requete = " select DOSSIER,upper(GENRE) from DOSSIER WHERE GENRE LIKE  'V%' ORDER BY DOSSIER"
    ici il me donner les champs ou le V est en majuscule, il ne prend pas en consideration les v en minuscule.

    J'aimerais savoir ou est mon erreur.
    Merci

  2. #2
    Expert éminent
    Avatar de StormimOn
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2005
    Messages
    2 593
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Sarthe (Pays de la Loire)

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 2 593
    Points : 7 660
    Points
    7 660
    Par défaut
    Sur quel SGBD tu travailles ?

    Sous SQL Server (je pense que pour d'autres SGBD on a une équivalence), les champs de type chaîne (char, varchar, ...) sont associés à une collation.

    Si tu ne veux pas tenir compte de la différence minuscule/majuscule, il suffit d'associer une collation indépendante de la casse pour ce champ. Comme French_CI_AI (Case Insensitive, Accent Insensitive).
    Pas de questions techniques par MP

  3. #3
    Modérateur
    Avatar de Sankasssss
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 842
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 842
    Points : 4 232
    Points
    4 232
    Par défaut
    Bonjour,
    Aurais-tu essayé ceci ???
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    dim requete as string
     
    requete = " select DOSSIER,GENRE from DOSSIER WHERE GENRE LIKE  'v%' ORDER BY DOSSIER"
    car avec LIKE '[Vv]%' il va te rechercher la chaine commencant par : [Vv]...

  4. #4
    Membre à l'essai
    Inscrit en
    Octobre 2006
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 28
    Points : 17
    Points
    17
    Par défaut
    j'ai essayer ce code que tu m'as suggérer mais il me donne seulement les champs qui commencent par le v miniuscule tandis que moi je veux pas qu'il tienne compte des majuscule ou miniscule. Car je veux qu'il me donner tout les ligne qui comment par V ou v



    Pour répondre à la question de Sankasssss je travaille avec des fichiers .dbf

  5. #5
    Modérateur
    Avatar de Sankasssss
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 842
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 842
    Points : 4 232
    Points
    4 232
    Par défaut
    dans vb (par ex dans un select sur un datatable) quand tu utilises un like il ne tien pas compte des majuscule et minucule. malheureusement apparemment ce n'est pas pareil sur les bd en requête direct

    test un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    dim requete as string
     
    requete = " select DOSSIER,GENRE from DOSSIER WHERE GENRE LIKE  'v%' and GENRE LIKE  'V%' ORDER BY DOSSIER"
    Sinon tu récupère tout via la requete et tu filtre via vb sur la table avec nomTable.select(expression)...

    PS : c'est pour répondre à StormimOn le nom de ton sgbd

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2005
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 11
    Points : 12
    Points
    12
    Par défaut
    Si tes données sont dans des dbf, la collation insensible à la casse s'appelle General.

    Mais si tu ne veux pas modifier cette collation depuis ton code client, et si tu te connectes à tes données par OleDB, tu devrais pouvoir utiliser de la syntaxe xBase dans ta requete:
    SELECT etc WHERE UPPER(GENRE) LIKE 'V%' etc

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    299
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 299
    Points : 330
    Points
    330
    Par défaut
    Si le Upper fonctionne, la solution de michelatoutfox est la plus "propre" mais si tu as une problématique de performance, il te faudra comparer entre cette solution et celle de Sankasssss dans laquelle tu remplaces le mot and par le mot or (sinon, ça ne marchera jamais... )

Discussions similaires

  1. [Dojo] Utiliser like dans une requete PHP
    Par moukit233 dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 14/09/2009, 16h40
  2. Utilisation de variable Builder dans une requete SQL
    Par _ben_ dans le forum C++Builder
    Réponses: 6
    Dernier message: 15/06/2007, 11h36
  3. Utilisation d'operateur booleen dans une requete
    Par olivier] dans le forum Langage SQL
    Réponses: 3
    Dernier message: 02/01/2006, 16h16
  4. Date et Like dans une requete
    Par skunkies dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 04/08/2005, 18h35
  5. Plusieurs LIKE dans une requete ?
    Par beastman007 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 22/02/2005, 12h10

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