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 :

[JDBC] récuperer n'importe quel champ sous forme de String


Sujet :

JDBC Java

  1. #1
    Membre éclairé Avatar de Hervé Saladin
    Homme Profil pro
    Ingénieur d'études en développement et déploiement d'applications
    Inscrit en
    Décembre 2004
    Messages
    647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur d'études en développement et déploiement d'applications
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2004
    Messages : 647
    Points : 799
    Points
    799
    Par défaut [JDBC] récuperer n'importe quel champ sous forme de String
    Salut,
    je cherche comment faire pour récuperer une valeur extraite d'un résultset sous forme de texte, quel que soit son type (car je ne connais pas le type à l'avance) ???
    La seule solution que j'ai immaginé, c'est de lire dans les meta-données le type de la colonne, puis, selon ce type, extraire la valeur avec la methode de la Classe ResulSet qui va bien et convertir en String
    exemple :
    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
    ResultSetMetaData metadata = monResultSet.getMetaData();
    // ... puis, dans une boucle ou je parcoure le resultset ...
    String leType=metadata.getColumnClassName(i);
     
    String valeurChaine;
     
    if(leType.equals("java.lang.String"))
    {
    	valeurChaine=monResultSet.getString(i);
    }
    else if(leType.equals("java.lang.Integer"))
    {
    	valeurChaine=String.valueOf(monResultSet.getInt(i));
    }
    else if(leType.equals("java.sql.Timestamp"))
    {
    	aleurChaine=String.valueOf(unResultat.getTimestamp(i).getDay())+"/"+String.valueOf(unResultat.getTimestamp(i).getMonth())+"/"+String.valueOf(unResultat.getTimestamp(i).getYear());
    }
    else if(leType.equals("     //... etc
    mais cela ne me convient pas : c'est sale et je risque de ne pas prendre en comptes certains types. En plus je m'en fous du type Java ou SQL de la donnée, puisque de toutes façons je la rebalance brute dans un flux XML, donc sous forme de texte.

    Quelqu'un saurait-il comment faire ça bien ?
    Merci d'avance ...

  2. #2
    zev
    zev est déconnecté
    Membre actif
    Inscrit en
    Octobre 2004
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 204
    Points : 220
    Points
    220
    Par défaut
    Tu peux pas recuperer des Object et balancer des monObject.toString() dans ton flux ?

    je propose ça mais je suis pas un pro non plus hein

  3. #3
    Membre éclairé Avatar de Hervé Saladin
    Homme Profil pro
    Ingénieur d'études en développement et déploiement d'applications
    Inscrit en
    Décembre 2004
    Messages
    647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur d'études en développement et déploiement d'applications
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2004
    Messages : 647
    Points : 799
    Points
    799
    Par défaut
    J'ai déjà essayé.
    Ca bug avec les dates ou les timestamp (SQLException) et pour certains types de données, ca me sort des trucs du genre [B@1360218
    Merci quand même pour ta tentative

  4. #4
    Membre éprouvé
    Avatar de yolepro
    Profil pro
    Architecte de système d'information
    Inscrit en
    Mai 2002
    Messages
    918
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Mai 2002
    Messages : 918
    Points : 1 144
    Points
    1 144
    Par défaut
    Tu peux utiliser une fonctionnalité Java qui s'appelle instanceof

    Tu peux l'utiliser dans un test logique tel qu'un if.

    ex
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    String toto = "toto";
     
    if (toto instanceof Integer) {
      // c'est un Integer
    } else if (toto instanceof String) {
      // c'est un String
    }
    Etre c'est etre relatif.

Discussions similaires

  1. recherche dans n'importe quel champs
    Par slack457 dans le forum Requêtes
    Réponses: 2
    Dernier message: 10/12/2009, 00h28
  2. [AC-2007] Récuperer une variable dans un sous form
    Par KIK83 dans le forum IHM
    Réponses: 0
    Dernier message: 19/11/2009, 23h52
  3. [Débutant]Récuperer les valeurs de panel sous forme de matrice
    Par feather1 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 19/02/2008, 18h09
  4. Réponses: 2
    Dernier message: 12/06/2007, 14h31
  5. [VBA]importer textes (.lvm) sous forme BD pour access
    Par rastalavista dans le forum VBA Access
    Réponses: 4
    Dernier message: 20/03/2007, 13h51

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