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

JDBC Java Discussion :

preparedStatement.setString change le charset ?


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 44
    Par défaut preparedStatement.setString change le charset ?
    Bonjour,

    Je realise des update sur une base mysql via preparedStatement et j'ai beaucoup de characteres allemand dans mes donnees tires d'un xml que je parse.
    Exemple: Hubertusstraße/Jägerweg

    J'ai vu de nombreux postes mais bien que cela semble etre le lie, je n'arrive pas a dessiner la solution.

    Quand j'extrais mon String du XML, je vois dans le debuggueur que les caracteres sont bien conserves. Ils sont encodes en UTF-8 meme si l'xml est configure pour l'ISO-8859-1.

    Si je realise le setString sur ma chaine, les caracteres perdent leur valeur et ca donne du Hubertusstraᅢ゚e/Jᅢᄂgerweg.

    Je peux changer ou non le charset de la colonne dans ma bdd ca change rien.
    De meme dans l'encodage avant le setString etc...

    Je n'ai pas vraiment d'indice, pourriez-vous m'aider s'il vous plait?

  2. #2
    Membre chevronné Avatar de djsnipe
    Inscrit en
    Mai 2008
    Messages
    440
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 440
    Par défaut
    Ton exemple semble bizarre.
    Il faut absolument que toute ta chaîne utilise le même encoding si tu ne veux pas de surprises :
    XML en UTF-8, dans l'entête et le corps, pour cela vérifie avec un "vrai" éditeur qui prend bien en charge cet encoding.
    Parsing en Java qui exploite l'encoding.
    BDD avec stockage dans cet encoding également
    Et restitution dans la console ou un fichier de log qui soit également UTF-8 :-)

  3. #3
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 44
    Par défaut
    Si je n'ai pas le choix quand a l'encodage des xml ?

  4. #4
    Expert éminent
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Billets dans le blog
    1
    Par défaut
    Salut,

    Citation Envoyé par oldergod Voir le message
    Ils sont encodes en UTF-8 meme si l'xml est configure pour l'ISO-8859-1.
    J'ai du mal à comprendre cette phrase... sachant qu'en interne Java utilise de l'UTF-16...


    Citation Envoyé par oldergod Voir le message
    Si je realise le setString sur ma chaine, les caracteres perdent leur valeur et ca donne du Hubertusstraᅢ゚e/Jᅢᄂgerweg.
    Tu as un problème d'encodage c'est sûr... mais il peut être situé à plusieurs endroits de la chaine de traitement :
    • Lors de la lecture du fichier XML (est-ce que tu précises bien le bon encodage).
    • Lors de la connexion à la base (avec MySQL il faut utiliser le paramètre characterEncoding sur l'URL de connexion) : http://dev.mysql.com/doc/refman/4.1/...-charsets.html
    • Lors de l'affichage (tu dois utiliser un support qui gère l'unicode ET qui possède une police adapté).


    a++

  5. #5
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    44
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 44
    Par défaut
    Merci beaucoup, c'etait bien le parametre characterEncoding dans l'URL de connexion que j'avais oublie !

    Merci.

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

Discussions similaires

  1. PreparedStatement et la méthode setString
    Par nddvlp dans le forum JDBC
    Réponses: 4
    Dernier message: 13/01/2015, 10h31
  2. Glassfish change le charset automatiquement
    Par mrik974 dans le forum Glassfish et Payara
    Réponses: 2
    Dernier message: 30/09/2011, 10h16
  3. PreparedStatement, setString et List
    Par babylone7 dans le forum JDBC
    Réponses: 4
    Dernier message: 29/09/2006, 09h35
  4. Réponses: 4
    Dernier message: 22/08/2006, 18h37
  5. Réponses: 3
    Dernier message: 22/07/2002, 14h19

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