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 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 JTable à partir de la base de données
    Salut,

    Voila je travaille avec la camposante JTable et je voulais insérer dedans le résultat d'une requête SQL. J'ai pas su comment le faire...

    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
    try {
    
                cn = new Connexion();
                 ///////***//////////////
    
                 jTable1.setModel(new javax.swing.table.DefaultTableModel(
        new Object [][] {
            {null, null, null, null, null},
            {null, null, null, null, null},
            {null, null, null, null, null},
            {null, null, null, null, null}
        },
        new String [] {
            "Numéro produit", "Nom Produit", "Prix unitaire", "Quantité", "Somme"
        }
    ) {
        Class[] types = new Class [] {
            java.lang.Integer.class, java.lang.String.class, java.lang.Float.class, java.lang.Integer.class, java.lang.Float.class
        };
        boolean[] canEdit = new boolean [] {
            false, false, false, true, false
        };
    
        public Class getColumnClass(int columnIndex) {
            return types [columnIndex];
        }
    
        public boolean isCellEditable(int rowIndex, int columnIndex) {
            return canEdit [columnIndex];
        }
    });
                 //////*********///////////////////
                ResultSet rss = cn.getResultat("Select ref,nom,pu from produit");
    //           stmt1 = cn.getConnection().createStatement();
    //           ResultSet rss = stmt1.executeQuery(requ);
                java.sql.ResultSetMetaData rsmd = rss.getMetaData();
                int colNo = rsmd.getColumnCount();
                while (rss.next()) {
                    Object[] objects = new Object[colNo];
                    for (int i = 0; i < colNo; i++) {
                        objects[i] = rss.getObject(i + 1);
                    }
                    jTable1.addRow(objects);
                }
                jTable1.setModel(aModel);
                jTable1.repaint();
    
            } catch (Exception ex) {
                Logger.getLogger(CommandeAjouterProduit.class.getName()).log(Level.SEVERE, null, ex);
            }
    
        }
    Ce code(en bleu) je l'ais recopier a partir de la commande Customize code lors d'un clic droit sur la camposante JTable ...
    Mais j'ai eu des erreurs (en rouge) ...
    Que dois-je mettre à la place des mots en rouge?
    Comment pourrais-je procéder pour règler ce problème?
    Merci à vous ....

  2. #2
    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
    J'ai modifié mon 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
     try {
    
                cn = new Connexion();
                 ///////***//////////////
    
    //             String[] tableColumnsName = {"Référence", "Nom", "Type", "Quantité", "Prix unitaire", "Seuil minimal"};
    //                DefaultTableModel aModel = new DefaultTableModel();
    //                aModel.setColumnIdentifiers(tableColumnsName);
                     jTable1.setModel(
                             new javax.swing.table.DefaultTableModel(
        new Object [][] {
            {null, null, null, null, null},
            {null, null, null, null, null},
            {null, null, null, null, null},
            {null, null, null, null, null}
        },
        new String [] {
            "Numéro produit", "Nom Produit", "Prix unitaire", "Quantité", "Somme"
        }
    ) {
        Class[] types = new Class [] {
            java.lang.Integer.class, java.lang.String.class, java.lang.Float.class, java.lang.Integer.class, java.lang.Float.class
        };
        boolean[] canEdit = new boolean [] {
            false, false, false, true, false
        };
    
        public Class getColumnClass(int columnIndex) {
            return types [columnIndex];
        }
    
        public boolean isCellEditable(int rowIndex, int columnIndex) {
            return canEdit [columnIndex];
        }
    });
    
                             
                 //////*********///////////////////
                ResultSet rss = cn.getResultat("Select ref,nom,pu from produit");
    //           stmt1 = cn.getConnection().createStatement();
    //           ResultSet rss = stmt1.executeQuery(requ);
                java.sql.ResultSetMetaData rsmd = rss.getMetaData();
                int colNo = rsmd.getColumnCount();
                while (rss.next()) {
                    Object[] objects = new Object[colNo];
                    for (int i = 0; i < colNo; i++) {
                        objects[i] = rss.getObject(i + 1);
                    }
                    aModel.addRow(objects);
                }
               
                jTable1.repaint();
    
            } catch (Exception ex) {
                Logger.getLogger(CommandeAjouterProduit.class.getName()).log(Level.SEVERE, null, ex);
            }
    
        }
    Mais j'ai eu l'erreur en rouge ...
    Que dois-je faire?

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Août 2002
    Messages
    43
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 43
    Points : 36
    Points
    36
    Par défaut
    De ce que je peux voir de ton code c'est que aModel n'est jamais initialiser ni même déclarer. Dans le code que tu as poster la déclaration et l'initialisation sont en commentaire.

    Si tu pouvais fournir le code d'erreur ce serait bien même si je crois que c'est un NullPointer exception.

    Bonne continuation

  4. #4
    Membre habitué
    Profil pro
    Architecte de système d’information
    Inscrit en
    Janvier 2007
    Messages
    439
    Détails du profil
    Informations personnelles :
    Localisation : Etats-Unis

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 439
    Points : 178
    Points
    178

Discussions similaires

  1. [MySQL] remplir tableau à partir de la base de données
    Par janyoura dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 29/03/2012, 13h40
  2. Remplir une JTable à partir de la base de données
    Par L'aigle de Carthage dans le forum Composants
    Réponses: 1
    Dernier message: 13/03/2012, 18h28
  3. [VS2008] Remplir ListView à partir d'une base de données
    Par paonus dans le forum Windows Forms
    Réponses: 1
    Dernier message: 03/07/2008, 21h32
  4. Réponses: 4
    Dernier message: 13/12/2007, 15h31
  5. Remplir jtable a partir d'une base de donnée mysql
    Par chris81 dans le forum Composants
    Réponses: 3
    Dernier message: 26/04/2007, 15h09

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