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

Access Discussion :

Recherche sans tenir compte des accents


Sujet :

Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 93
    Points : 73
    Points
    73
    Par défaut Recherche sans tenir compte des accents
    Bonjour,

    Je dois faire une requête en SQL pour interroger une base ACCESS 2003 me permettant de lister des personnes. Le problème c'est que dans la liste je me retrouve avec dans la colonne prénom des "CEDRIC", "cedric" et "cédric".

    avec une requete du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * 
    FROM T_PERSONNE 
    WHERE PRENOM='CEDRIC'
    Je récupère bien les "CEDRIC" et "cedric" mais pas "cédric". Existerai-t-il un moyen pour que je puisse tout récupérer d'un coup sans tenir compte de la casse et des accents ?

    Merci beaucoup.

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 086
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 086
    Points : 42 925
    Points
    42 925
    Par défaut
    Vas voir
    Je pense que tu avanceras un peu dans ta quête

  3. #3
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    tu peux ajouter un champ dans la requête en utilisant une fonction pour enlever tous les accents.

    (à mettre dans un module de code)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Private Declare Function FoldString Lib "kernel32.dll" Alias _
            "FoldStringA" (ByVal dwMapFlags As Long, ByVal lpSrcStr As Long, _
            ByVal cchSrc As Long, ByVal lpDestStr As Long, ByVal cchdest As Long) As Long
     
    Function OteAccents(ByVal str As String) As String
     
        Dim i As Integer
        OteAccents = Space(Len(str))
     
        For i = 0 To (Len(str) - 1) * 2 Step 2
            FoldString &H40, StrPtr(str) + i, 1, StrPtr(OteAccents) + i, 1
        Next i
     
    End Function

  4. #4
    Membre régulier
    Inscrit en
    Mai 2006
    Messages
    87
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 87
    Points : 80
    Points
    80
    Par défaut
    on peu auusi tout simplement ecrire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * 
    FROM T_PERSONNE 
    WHERE PRENOM='C?DRIC'
    mais on trouvera aussi tous les cadric , codric.....etc

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    93
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 93
    Points : 73
    Points
    73
    Par défaut
    Je vous remercie de vos aides. J'ai oublié de préciser que le prénom serai saisie dans une boite de dialogue MFC et que le code derrière sera en C++. Donc le "cédric" n'est qu'un exemple pour montrer le problème des accents dans le prénom.

  6. #6
    Membre éprouvé Avatar de Ric500
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    970
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

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

    Informations forums :
    Inscription : Août 2004
    Messages : 970
    Points : 1 162
    Points
    1 162
    Par défaut
    Bonjour Killerjeff

    As-tu as essayé un truc du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * 
    FROM T_PERSONNE 
    WHERE UCASE(PRENOM)='CEDRIC'

  7. #7
    Membre chevronné

    Profil pro
    Inscrit en
    Avril 2006
    Messages
    1 399
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 399
    Points : 2 221
    Points
    2 221
    Par défaut
    bonjour,

    une autre alternative sans préjuger de la rapidité est d'utiliser la fonction strconv :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    StrConv([prenom],1,4)
    qui réalise une conversion du contenu en majuscule et transforme les lettres accentuées en lettres sans accent.

    Cordialement,

    Philippe

Discussions similaires

  1. Recherche sans tenir compte des accents ni de la casse
    Par P'tite étoile dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 29/01/2013, 15h42
  2. Réponses: 1
    Dernier message: 08/06/2009, 11h44
  3. Filtrer sans tenir compte des Accents
    Par dsolheid dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 23/10/2008, 13h29
  4. "Filter" sur DataBinding sans tenir compte des Accents
    Par dsolheid dans le forum VB.NET
    Réponses: 3
    Dernier message: 23/10/2008, 10h16
  5. Réponses: 1
    Dernier message: 17/08/2006, 20h27

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