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

Composants Java Discussion :

Remplir une JTable à partir de la base de données


Sujet :

Composants Java

  1. #1
    Débutant  
    Inscrit en
    Mai 2006
    Messages
    705
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 705
    Points : 117
    Points
    117
    Par défaut Remplir une JTable à partir de la base de données
    Bonjour à tous,

    Je sais qu'il s'agit d'une question très posée dans ce forum, mais j'ai cherché et j'ai pas trouvé une réponse satisfaisante ...

    Dans NetBeans lorsque je (drage and drop) une composante Jtable dans ma fenêtre, je veux qu'elle soit remplie à partir de la base de données...
    Si je fouille un peu dans la section "Generated Code" dans source, je trouve ce 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
     
    tableCust.setModel(new javax.swing.table.DefaultTableModel(
                new Object [][] {
                    {null, "", ""},
                    {null, "", ""},
                    {null, "", ""},
                    {null, "", ""}
                },
                new String [] {
                    "CIN", "NOM", "PRENOM"
                }
            ) {
                Class[] types = new Class [] {
                    java.lang.Integer.class, java.lang.String.class, java.lang.String.class
                };
                boolean[] canEdit = new boolean [] {
                    true, false, false
                };
     
                public Class getColumnClass(int columnIndex) {
                    return types [columnIndex];
                }
     
                public boolean isCellEditable(int rowIndex, int columnIndex) {
                    return canEdit [columnIndex];
                }
            }
     
        );
    Je dispose aussi d'une méthode qui sélectionne la liste des personnes depuis ma base de données et qui me retourne une ResultSet, le problème c'est que j'ai pas su ou mettre le traitement qui va "fetcher" cette ResultSet?

    J'espère bien que vous m'avez bien compris!

    Merci!

  2. #2
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    La méthode propre de faire est de:


    • Créer un objet correspondant à une ligne de ta JTable (un attribut par champ visible)
    • Créer un modèle héritant d'AbstractTableModel se basant sur un liste de ces objets
    • Créer une méthode qui va chercher les données en base puis crée la liste d'objets à partir de ces données.

    Bref, il faut découpler la partie récupération de données de celle de la création de la JTable. On évite de manipuler les couches de récupération des données dans le code de l'interface. De plus la récupération doit se faire dans un thread séparé pour éviter de bloquer l'interface graphique.

    Trois tutos à lire obligatoirement pour comprendre comment faire:


    Le tutoriel sur la JTable pour apprendre à bien utiliser les modèles, comment manipuler le composant JTable, changer son apparence & cie: http://baptiste-wicht.developpez.com.../swing/jtable/


    Pour apprendre a modéliser correctement ses couches de récupération de données: http://cyrille-herby.developpez.com/...c-pattern-dao/


    Pour savoir comment gérer proprement les tâches longues en Swing dans un thread séparé afin de ne pas bloquer le thread de rendu de l'interface graphique (aka EDT), en utilisant un SwingWorker: http://rom.developpez.com/java-swingworker/
    Hey, this is mine. That's mine. All this is mine. I'm claiming all this as mine. Except that bit. I don't want that bit. But all the rest of this is mine. Hey, this has been a really good day. I've eaten five times, I've slept six times, and I've made a lot of things mine. Tomorrow, I'm gonna see if I can't have sex with something.

Discussions similaires

  1. [MySQL] Afficher une image à partir stockée en base de données
    Par arti2004 dans le forum PHP & Base de données
    Réponses: 22
    Dernier message: 21/06/2011, 19h40
  2. Remplir JTable à partir de la base de données
    Par L'aigle de Carthage dans le forum Composants
    Réponses: 3
    Dernier message: 11/11/2009, 10h02
  3. Remplir une jList à partir d'une base mySQL
    Par aymentouhent dans le forum JDBC
    Réponses: 1
    Dernier message: 26/10/2009, 12h27
  4. Réponses: 4
    Dernier message: 13/12/2007, 14h31
  5. [MySQL] Afficher une photo à partir de la base de données
    Par microcongo dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 07/09/2005, 17h29

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