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

MySQL Discussion :

Supprimer les accents dans une colonne de type varchar dans MYSQL


Sujet :

MySQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mars 2017
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Alimentation

    Informations forums :
    Inscription : Mars 2017
    Messages : 19
    Points : 22
    Points
    22
    Par défaut Supprimer les accents dans une colonne de type varchar dans MYSQL
    Bonjour,

    je viens vers vous suite a un petit problème de jointure via talend entre un fichier source et MySQL.
    En fait j'ai déjà des données insérées en bdd et je dois faire un inner join dans talend entre la source et l'existant dans MySQL sur un champ libellé(oui je sais que c'est pas très académique mais j'ai trouvé ça comme ça, donc je m'adapte ).
    Sauf que des fois, on a un libellé avec accent dans la base et dans le fichier on a pas d'accent, ce qui fait que la donnée ne match pas.
    Exemple: dans le fichier on a:
    libellé = Pleides
    En base Mysql on a:
    libellé = Pléides

    Coté talend, j'arrive bien à enlever les accents sur la colonne avec cette fonction "TalendString.removeAccents" avant insert
    il me reste à updater la colonne libellée pour enlever les accents sur la colonne libellé en BDD (Mysql).
    j'ai regardé un peu sur le net et j'ai trouver la fonction "COLLATE" + quelque chose du genre "latin2_general_ci" etc... mais rien ne me donne satisfaction.

    Est ce qu'il y aurait quelque chose pour updater et enlever les accents (priorité N°1) et éventuellement si possible , définir cette colonne comme ne recevant pas d'accent sur Mysql svp?

    Merci de votre aide par avance

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 772
    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 772
    Points : 52 732
    Points
    52 732
    Billets dans le blog
    5
    Par défaut
    Il suffit d'utiliser une collation qui fait confusion des caractères diacritiques (accent, ligature, cédille...)

    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/ * * * * *

  3. #3
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 947
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Je ne comprends pas bien la question.
    Puisque vous êtes dans Talend pour faire la jointure utilisez "TalendString.removeAccents" également pour les données en provenance de mysql.

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 909
    Points
    38 909
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par boubafia80 Voir le message
    Est ce qu'il y aurait quelque chose pour updater et enlever les accents (priorité N°1) et éventuellement si possible , définir cette colonne comme ne recevant pas d'accent sur Mysql svp?
    La clause COLLATE peut tout à fait être spécifiée au niveau de la colonne dans l'ordre CREATE TABLE, auquel cas, avec une collation insensible aux accents (le plus souvent suffixée _AI), vous n'aurez plus aucun souci.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Mars 2017
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Alimentation

    Informations forums :
    Inscription : Mars 2017
    Messages : 19
    Points : 22
    Points
    22
    Par défaut
    Bonjour et merci pour vos retour,

    avant de poster cette demande j'avais essayé plein de COLLATE mais j'avais tjrs une erreur en sortie
    SQL Error [1273] [HY000]: Unknown collation:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select 'áéíóú' COLLATE utf8_general_AI;              
    -- latin2_general_ci
    -- latin2_general_ci
    -- utf8mb4_general_ci   ok
    -- COLLATE latin2_general_ci
    -- latin1_swedish_ci
    -- big5_chinese_ci
    -- utf8_general_ci
    -- COLLATE FRENCH_CI_AI
    ;
    Auriez-vous un COLLATE qui marche svp?

    Merci par avance

  6. #6
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 381
    Points : 19 065
    Points
    19 065
    Par défaut
    Salut à tous.

    Code MySql : 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
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE IF NOT EXISTS `base`
            DEFAULT CHARACTER SET `utf8`
            DEFAULT COLLATE       `utf8_unicode_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `test`
    --------------
     
    --------------
    CREATE TABLE `test`
    ( `id`       integer unsigned NOT NULL auto_increment Primary Key,
      `message`     char(10)     NOT NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`utf8` COLLATE=`utf8_unicode_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `test` (`message`) values
      ('e'),('é'),('è'),('ê')
    --------------
     
    --------------
    select * from `test`
    --------------
     
    +----+---------+
    | id | message |
    +----+---------+
    |  1 | e       |
    |  2 | é       |
    |  3 | è       |
    |  4 | ê       |
    +----+---------+
    --------------
    select * from `test` where `message` = 'e'
    --------------
     
    +----+---------+
    | id | message |
    +----+---------+
    |  1 | e       |
    |  2 | é       |
    |  3 | è       |
    |  4 | ê       |
    +----+---------+
    --------------
    COMMIT
    --------------
     
    Appuyez sur une touche pour continuer...

    Cordialement.
    Artemus24.
    @+
    Si vous êtes de mon aide, vous pouvez cliquer sur .
    Mon site : http://www.jcz.fr

Discussions similaires

  1. Réponses: 6
    Dernier message: 14/02/2008, 16h32
  2. Supprimer les accents dans une chaîne
    Par SuperChafouin dans le forum Langage
    Réponses: 4
    Dernier message: 17/12/2007, 17h28
  3. Supprimer les accent dans une chaine
    Par avigeilpro dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 12/09/2006, 11h04
  4. Récupérer les infos d'une colonne de type DataSet
    Par Zugg dans le forum Bases de données
    Réponses: 2
    Dernier message: 01/02/2006, 14h46

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