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

API standards et tierces Java Discussion :

[derby] Problème d'encodage


Sujet :

API standards et tierces Java

  1. #1
    Expert confirmé
    Avatar de le y@m's
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    2 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2005
    Messages : 2 636
    Points : 5 778
    Points
    5 778
    Par défaut [derby] Problème d'encodage
    Salut à tous,

    J'essaye actuellement la base de donnée derby (en embarqué) et je me retrouve avec un problème que je n'arrive pas à résoudre.
    Lorsque j'insère du texte avec des accents dans la base, je me retrouve avec des "é" and co.
    Cela ressemble fort à un problème d'encodage, cependant je ne comprends pas d'où il vient. On dirai que "l'insert" et le "select" ne se font pas avec le même encodage .

    Voici un exemple 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
    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
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    public class Test {
     
        public Test() {
        }
     
        public static void main(String ...args) {
            try {
                Class.forName("org.apache.derby.jdbc.EmbeddedDriver").newInstance();
                Connection connection = DriverManager.getConnection("jdbc:derby:bdtest;create=true");
                try {
                    String query = "CREATE TABLE test ( label VARCHAR(100) NOT NULL )";
                    Test.executeUpdate(connection, query);
                    query = "INSERT INTO test (label) VALUES ('test 1 : é')";
                    Test.executeUpdate(connection, query);
                    query = "INSERT INTO test (label) VALUES ('test 2 : è')";
                    Test.executeUpdate(connection, query);
                    query = "INSERT INTO test (label) VALUES ('test 3 : à')";
                    Test.executeUpdate(connection, query);
     
     
                    query = "SELECT label FROM test";
                    List<Object[]> rows = Test.executeQuery(connection, query);
                    for(Object[] row : rows) {
                        System.out.println(row[0]);
                    }
                } finally {
                    connection.close();
                }
            } catch(Exception e) {
                e.printStackTrace();
            }
        }
     
     
        public static List<Object[]> executeQuery(Connection connection, String pQuery)
        throws Exception {
            Statement stmt = null;
            ResultSet rSet = null;
            try {
                stmt = connection.createStatement();
                rSet = stmt.executeQuery(pQuery);
                ResultSetMetaData rsmd = rSet.getMetaData();
                int columnCount = rsmd.getColumnCount();
                List<Object[]> rList = new ArrayList<Object[]>();
                while(rSet.next()) {
                    Object[] tmp = new Object[columnCount];
                    for(int i = 0;i < columnCount;i++) {
                        tmp[i] = rSet.getObject(i + 1);
                    }
                    rList.add(tmp);
                }
                return rList;
            } finally {
                if(rSet != null) {
                    rSet.close();
                }
                if(stmt != null) {
                    stmt.close();
                }
            }
        }
     
        public static int executeUpdate(Connection connection, String query)
        throws Exception {
            Statement stmt = null;
            try {
                stmt = connection.createStatement();
                int rLineCount = stmt.executeUpdate(query);
                return rLineCount;
            } finally {
                if(stmt != null) {
                    stmt.close();
                }
            }
        }
     
    }
    La sortie donne :
    test 1 : é
    test 2 : è
    test 3 : Ã
    Comment faire pour résoudre ce problème ?
    J'avoue être un peu perdu .

    Merci d'avance.

  2. #2
    Expert éminent sénior
    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
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Essayes en spécifiant l'encodage avec la propriété derby.ui.codeset :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.setProperty("derby.ui.codeset", "8859_1");
    a++

  3. #3
    Expert confirmé
    Avatar de le y@m's
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    2 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2005
    Messages : 2 636
    Points : 5 778
    Points
    5 778
    Par défaut
    Ca ne change rien .

  4. #4
    Expert confirmé
    Avatar de le y@m's
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    2 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2005
    Messages : 2 636
    Points : 5 778
    Points
    5 778
    Par défaut
    Personne d'autre n'a d'idée .

    C'est vraiment bizarre comme truc, est-ce que ça ne pourrait pas venir du driver jdbc qui est mal foutu ?



  5. #5
    Expert confirmé
    Avatar de le y@m's
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    2 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2005
    Messages : 2 636
    Points : 5 778
    Points
    5 778
    Par défaut
    Bon, je me suis repenché sur le problème et j'ai finalement trouvé ce qui n'allait pas. Cela venait tout simplement de l'encodage du fichier source qui n'était pas celui du système.

    Donc deux solution :
    • soit mettre le fichier source dans l'encodage par défaut (celui du système).
    • soit compiler en spécifiant l'encodage du fichier avec l'option -encoding de javac (dans mon cas : -encoding UTF8).
    Un truc tout c** quoi

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

Discussions similaires

  1. [CSV] Problème d'encodage
    Par simoryl dans le forum Langage
    Réponses: 13
    Dernier message: 18/04/2012, 15h20
  2. Problème d'encodage avec Python
    Par tse_tilky_moje_imja dans le forum Général Python
    Réponses: 2
    Dernier message: 22/02/2006, 14h36
  3. Problème d'encodage en Unicode
    Par Skreo dans le forum Entrée/Sortie
    Réponses: 5
    Dernier message: 28/12/2005, 10h43
  4. Problème d'encodage sur MySql 4.1
    Par Blanchet dans le forum Outils
    Réponses: 1
    Dernier message: 04/12/2005, 04h53
  5. [XML::PARSER] Problème d'encodage
    Par frangin2003 dans le forum Modules
    Réponses: 13
    Dernier message: 05/09/2005, 14h59

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