[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:
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 ... :D