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 :

Utilisation de getColumn()


Sujet :

JDBC Java

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut Utilisation de getColumn()
    Bonjour,

    Je dois parcourir le contenu complet d'une base de données. Pour se faire, et dans un premier temps, je me servais des fonctions getTable() et getColumn() de cette façon:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    ResultSet tab = meta.getTables(......);
     
    while(tab.next()){    //Parcours des tables
      //TRAITEMENT
      ResultSet col = meta.getColumn(..,..,tab.getString("TABLE_NAME"),...);
      while(col.next()){  //Parcours des colonnes d'une table
      //TRAITEMENT
      }
    }
    Mais on m'a conseillé de n'utiliser QUE getColumn() pour un soucis de performances (moins de demandes à effectuer vers la base de données).

    J'ai tout essayé de long en large, cherché partout mais le problème reste le même. En utilisant seulement getColumn() on va parcourir le tout en une seule boucle, et je ne trouve aucun moyen pour détecter le changement de table récupérable avec un col.getString("TABLE_NAME") que l'on avait avant grâce à la boucle while(tab.next());

    J'espère avoir été assez claire , en vous remerciant pour votre aide.

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    ben si t'arrive à récupérer le nom de la table via col.getString("TABLE_NAME"), ça ne devrais pas être un problème de constater que oui ou non c'est le même qu'à l'itération précédente. Qu'est-ce qui te bloque concrêtement??

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2014
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2014
    Messages : 3
    Points : 4
    Points
    4
    Par défaut
    Eh bien merci mais j'ai finalement réussi.

    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
      DatabaseMetaData meta = connexion.getMetaData();
     
                ResultSet cols = meta.getColumns(null, null, null, null);
                ResultSetMetaData rm = cols.getMetaData();
                int nbcols = rm.getColumnCount();
     
                while (cols.next()) {
                    for (int i = 0; i < nbcols; i++) {
                        //System.out.println(cols.getString(i+1)); 
     
                        if ("TABLE_NAME".equals(rm.getColumnName(i + 1))) {
                            if (listetab.containsKey(cols.getString(i + 1))) {
                                //TRAITEMENT
                            } else {
                                //TRAITEMENT
                            }
                        }
                    }
                }

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

Discussions similaires

  1. utiliser les tag [MFC] [Win32] [.NET] [C++/CLI]
    Par hiko-seijuro dans le forum Visual C++
    Réponses: 8
    Dernier message: 08/06/2005, 15h57
  2. Réponses: 4
    Dernier message: 05/06/2002, 14h35
  3. utilisation du meta type ANY
    Par Anonymous dans le forum CORBA
    Réponses: 1
    Dernier message: 15/04/2002, 12h36
  4. [BCB5] Utilisation des Ressources (.res)
    Par Vince78 dans le forum C++Builder
    Réponses: 2
    Dernier message: 04/04/2002, 16h01
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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