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

MS SQL Server Discussion :

Requête SQL SELECT sans accent


Sujet :

MS SQL Server

  1. #1
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    279
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 279
    Points : 175
    Points
    175
    Par défaut Requête SQL SELECT sans accent
    Bonjour à tous,

    Bizarrement je ne trouve pas de solution sur internet à mon problème.

    Voilà je cherche à faire une simple requête SELECT sans tenir compte des accent, cela dans un but de comparaison.

    Exemple :
    J'ai le libellé "réunion" en base.
    Et je souhaiterais que ma requête du type : "Select MonChamp1 from MaTable where MonChamp2 like 'reunion' me renvoi quelque chose ...

    Avez vous des éléments de réponse sachant que je travaille aujourd'hui avec SQL Server (2008 R2 pour les intimes)

    @ +

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Dans ce cas il vous faudrait passer la collation de la colonne dans une collation non-sensible aux accents.

    En supposant que vous avez donné la collation French_CI_AS :

    - CI : Case Insensitive : insensible à la casse
    - AS : Accent Sensitive : sensible aux accents

    Il vous faut écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT	MaColonne1
    FROM	dbo.MaTable
    WHERE	MaColonne2 LIKE 'reunion' COLLATE French_CI_AI
    Pour Case Insensitive et Accent Insensitive

    @++

  3. #3
    Invité
    Invité(e)
    Par défaut
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    -- IMPORTANT !!! Sensibilité aux casses / accentuations avec les collations
     
    -- La table
    IF OBJECT_ID('MaTable', 'U') IS NOT NULL
    DROP TABLE MaTable
    GO
     
    CREATE TABLE MaTable
    (Id int identity(1,1),
    Ch1 varchar(50),
    Ch2 varchar(50))
    GO
     
    -- Les données de test
    INSERT INTO MaTable(Ch1, Ch2) VALUES ('Tête','Tete')
    INSERT INTO MaTable(Ch1, Ch2) VALUES ('Tête','TeTe')
    INSERT INTO MaTable(Ch1, Ch2) VALUES ('Tete','TeTe')
    INSERT INTO MaTable(Ch1, Ch2) VALUES ('Tete','Tete')
    GO
     
    -- Comparaison
    -- Sensible aux minuscules / majuscules et aux accents
    SELECT *
    FROM MaTable WHERE Ch1 = Ch2 COLLATE French_BIN
     
    -- Comparaison
    -- Sensible aux minuscules / majuscules
    SELECT *
    FROM MaTable WHERE Ch1 = Ch2 COLLATE French_CS_AI
     
    -- Comparaison
    -- Sensible aux accents
    SELECT *
    FROM MaTable WHERE Ch1 = Ch2 COLLATE French_CI_AS
     
    -- Comparaison
    -- Non sensibles aux 2
    SELECT *
    FROM MaTable WHERE Ch1 = Ch2 COLLATE French_CI_AI
     
    GO
     
    -- Supprime la table
    DROP TABLE MaTable
    GO

  4. #4
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    279
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 279
    Points : 175
    Points
    175
    Par défaut
    J'ai testé ce que vous me proposez mais je n'arrive pas à mes fins ...

    Dans mon cas, je souhaite trouver tous les libellés (ORGANISME) du fichier #DataContactCSV qui n'existe pas dans le fichier Organisme (Champ Or_libelle) avec la contrainte des accents. Voici ma requête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select distinct ORGANISME
      from #DataContactCSV
     where lower(ORGANISME) not in (Select lower(Or_libelle) from Organisme)
    Si j'essai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select distinct ORGANISME
      from #DataContactCSV
     where lower(ORGANISME) not in (Select lower(Or_libelle) from Organisme COLLATE French_CS_AI)
    Ca ne marche pas ...

    Savez-vous pourquoi ?

  5. #5
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    279
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 279
    Points : 175
    Points
    175
    Par défaut Trouvé !
    Finalement c'est bon, voici la soluc :

    select distinct ORGANISME from #DataContactCSV where lower(ORGANISME) COLLATE French_CI_AI not in (Select lower(Or_libelle) COLLATE French_CI_AI from Organisme)

    En fait je ne mettais pas mon COLLATE au bon endroit.

  6. #6
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 763
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 763
    Points : 52 554
    Points
    52 554
    Billets dans le blog
    5
    Par défaut
    Vous n'avez pas besoin de tout ce pâté en l’occurrence supprimez les LOWER inutile. Le CI du collate signifie insensible à la casse !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  7. #7
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    De plus vous pouvez écrire votre requête ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select distinct
           t1.ORGANISME
      from #DataContactCSV as t1
     where not exists (select null
                         from Organisme as t2
                        where t2.Or_libelle = t1.ORGANISME COLLATE French_CI_AI);
    FB (SQLpro) je t'ai rajouté la parenthèse manquante

  8. #8
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    279
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 279
    Points : 175
    Points
    175
    Par défaut
    Merci à tous

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

Discussions similaires

  1. requête SQL select avec commande XP (xp_fileexist)
    Par cyrano_de_bergerac dans le forum Développement
    Réponses: 2
    Dernier message: 24/08/2009, 17h49
  2. Requête SQL + Select NULL
    Par Imad_ing dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/08/2008, 09h02
  3. Ma requête SQL SELECT ne passe pas dans next()
    Par Somato dans le forum Bases de données
    Réponses: 17
    Dernier message: 02/06/2008, 15h45
  4. Enregistrer une requête SQL SELECT sous VB Express
    Par Invité dans le forum VB.NET
    Réponses: 6
    Dernier message: 29/01/2008, 09h04
  5. [Requête/SQL]selection toutes colonnes sauf une
    Par alcabk dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 17/04/2007, 09h01

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