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 :

mise à jour automatique de jtable à partir de BD


Sujet :

Composants Java

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 7
    Par défaut mise à jour automatique de jtable à partir de BD
    Bonjour à tous,
    Je suis en train de développez une petite appli avec swing et mysql et j'a un souci que j'arrive pas à régler.
    J'ai une classe "Gestion" qui contient une jtable, c'est le point d'entrée de l'application.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    private JScrollPane getJScrollPane() {
    		if (jScrollPane == null) {
    			jScrollPane = new JScrollPane();
    			jScrollPane.setViewportView(new BdSelection());
    		} 
    		return jScrollPane;
    	}
    Au démarrage, l'appli va chercher les donnée dans la classe "BdSelection" et les afficher dans la table. Voici le code de cette classe
    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
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
     
    public class BdSelection extends AbstractTableModel 
    {
        private static final long serialVersionUID = 1L;
        private static String url;
        private Vector data = new Vector();
        private Vector columnNames = new Vector <String> ();
        private JTable jTableClient;
     
        public BdSelection ()
        {
     
        try
        {
        try
        {
        Class.forName("com.mysql.jdbc.Driver");
        }
        catch (ClassNotFoundException ex)
        {
         //....
        }
        url ="jdbc:mysql://localhost:3306/gestion_stock";
        System.out.println("connection à la BdSelection");
     
        Connection connection = DriverManager.getConnection(url, "root", "");
        Statement stmt = connection.createStatement();
     
        String sql = "select * FROM client";
        ResultSet rs = stmt.executeQuery(sql);
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();
     
        for (int i = 1; i <= columns; i++) {
                columnNames.addElement(md.getColumnName(i));
            }
     
        while (rs.next()) {
        Vector row = new Vector(columns);
     
        for (int i = 1; i <= columns; i++) {
        row.addElement(rs.getObject(i));
        }
     
        data.add(row);
        }//fin while
        rs.close();
        stmt.close();
        }
        catch (SQLException e)
        {
        System.out.println(e.getMessage());
        System.out.println(e.getStackTrace());
        }
        }//fin constructeur
     
        @Override
        public int getColumnCount() {
            return columnNames.size();
        }
     
        @Override
        public int getRowCount() {
            return data.size();
        }
     
        @Override
        public Object getValueAt(int row, int column) {
            Vector rowData = (Vector) data.elementAt(row);
            return rowData.elementAt(column);
        }
     
        @Override
        public String getColumnName(int idx) {
            //return cols[idx];
            return (String)columnNames.elementAt(idx);
        }
     
        @Override
        public boolean isCellEditable(int arg0, int arg1) {
            return true;
        }
        @SuppressWarnings("unchecked")
        @Override
        public void setValueAt(Object value, int row, int col) {
            /*data.setElementAt( value, (row*getColumnCount())+col);
            fireTableDataChanged();*/
            Vector dataRow = (Vector)data.elementAt(row);
            dataRow.setElementAt(value, col);
            fireTableCellUpdated(row, col);
        }
    }
    Jusqu'à là, pas de souci. Mais mon mon appli contient aussi une classe qui permet d'insérer des données "AjouterNouveauClient". L'insertion se fait en cliquant sur un bouton.
    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
     
    public class AjouterNouveauClient extends JDialog {
    ....
    public JButton getJButton() {
    		if (jButton == null) {
    			jButton = new JButton();
    			jButton.setText("Valider");
    			jButton.addActionListener(new java.awt.event.ActionListener() {
    				public void actionPerformed(java.awt.event.ActionEvent e) {
     
                                        NouveauClient nc = new NouveauClient();//instanciation d'une classe contenant les champs et les getters/setter
                                        nc.setIdClient(jTextFieldIdClient.getText().trim());
                                        nc.setNom(jTextFieldNom.getText().trim());
    				    nc.setPrenom(jTextFieldPrenom.getText().trim());
    				    nc.setAdresse(jTextFieldAdresse.getText().trim());
    				    nc.setCodePostal(jTextFieldCp.getText().trim());
    				     nc.setCivilite((String)jComboBoxCivilite.getSelectedItem());
    				    nc.setVille(jTextFieldVille.getText().trim());
    				    nc.setTel(jTextFieldTel.getText().trim());
    				    nc.setFax(jTextFieldFax.getText().trim());
    				    nc.setMail(jTextFieldMail.getText().trim());
     
    				    new BaseDonnees(nc);                                   
    				}
    			});
    		}
    		return jButton;
    	}
    ....
    }
    L'insertion de ces données se fait via une autre classe "BaseDonnees"
    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
     
    public class BaseDonnees  {
    .....
    public BaseDonnees (NouveauClient nClient){
        String sql = "INSERT INTO client (Id, Civilité, Nom, Prénom, Adresse, Code_postal, Ville, Téléphone, Fax, Mail) " +
                "VALUES ("+
                "'"+nClient.getIdClient()+"'," 
                +"'"+nClient.getCivilite()+"',"
                +"'"+nClient.getNom()+"'," 
                +"'"+nClient.getPrenom() +"',"
                +"'"+nClient.getAdresse()+ "',"
                +"'"+nClient.getCodePostal() + "',"
                +"'"+nClient.getVille()+ "',"
                +"'"+nClient.getTel()+"',"
                +"'"+nClient.getFax()+"',"
                +"'"+nClient.getMail()+"'"+")";
     
                System.out.println("Insertion dans la base ++++++++++++++");  
                .......
        }
    }
    L'insertion dans la base se fait aussi. Mais ce que je voudrais, c'est que dès que j'inère ces donnéés dans la base, elles soient également affichées dynamiquement dans la table. J'ai essayé plein de choses préconisées dans des forums et tutos mais en vain. Jusqu'à maintenant, pour mettre ces nouvelles données dans la table, je suis obligé de redémarrer l'application.

    Comment faire de sorte que les données soient intégrées dans la table dynamiquement.

    Merci à tous de m'aider.

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 142
    Par défaut
    Hello !

    Une petite question avant de te répondre... Pourquoi avoir ceci dans la class BdSelection:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    private JTable jTableClient;
    ?

    Donc pour te répondre:
    Pour commencer, tu dois avoir un getter quelque part du BdSelection que ta JTable utilise.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    private BdSelection getTableModel();
    Ensuite, tu as 2 possibilités.
    La première est de mettre une méthode "rafraichitModel()" dans la classe BdSelection qui refait tout le select (ce que tu as mis dans le constructor) , puis tu fais un fireTableDataChanged();.
    Ensuite, dans l'actionPerformed, après avoir fait l'insert, tu appelles cette méthode:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    XXX.getTableModel().rafraichit();
    Ca, c'est la méthode barbare ^^

    Sinon, la 2e solution est de créer une méthode "add(NouveauClient nClien)" dans la classe BdSelection qui va ajouter à ton vector data une nouvelle ligne, puis tu fais un fireTableRowsInserted();

    Et tu appel aussi cette méthode dans l'actionPerformed !

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 7
    Par défaut
    Merci DeathMaker de ta réponse. concernant private JTable jTableClient;
    dans la classe BdSelection, c'est un oublie de ma part quand j'ai posté ce message. Je vais essayé l'astuce que tu m'as donné.

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 7
    Par défaut
    je viens d'essayer les 2 méthodes que tu m'as indiquées, ça ne marche pas. Je bloque sur ce truc depuis des jours.

  5. #5
    Membre Expert
    Avatar de CheryBen
    Inscrit en
    Mai 2005
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Âge : 44

    Informations forums :
    Inscription : Mai 2005
    Messages : 1 599
    Par défaut
    Putôt que de dire que ça ne marche pas, il faut donner le comportement et les erreurs que tu obtiens. (ainsi que le code utilisé)

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 7
    Par défaut
    je n'ai pas de message d'erreur. Je récupère bien les données qui viennent d'être enregistrées dans le vector mais ces changements ne sont pas répercutés dans la table.

  7. #7
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 142
    Par défaut
    Comme le dit CheryBen, tu peux poster ton code ?

    Si tu veux vraiment pas le poster, penses à mettre des traces (System.out.println("je suis à tel endroit"); ) pour être sûr que tu passes aux bons endroits !
    Est ce que tu appelles bien les méthodes fireTableXXXX après chaque opération sur ton Vector data ?

  8. #8
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 7
    Par défaut
    Merci de vos messages. voici mes codes (J'ai pas mis la classe NouveauClient car il ne contient que les champs et les getters/setters

    Classe qui contient le main.

    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
     
    public class Gestion_Stock extends JFrame {
    .......
    .......
     public JTable getJTableClient()  {
     
        if (jTableClient == null){
     
        jTableClient = new JTable(new BdSelection());
     
        jTableClient.setAutoCreateRowSorter(true);
        }
        return jTableClient;
        }
    .......
    .......
    }
    Classe AjouterNouveauClient
    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
     
    public class AjouterNouveauClient extends JDialog {
    .......
    .......
     
    public JButton getJButton() {
    		if (jButton == null) {
    			jButton = new JButton();
    			jButton.setText("Valider");
    			jButton.addActionListener(new java.awt.event.ActionListener() {
    				public void actionPerformed(java.awt.event.ActionEvent e) {
     
                                        NouveauClient nc = new NouveauClient();
                                        nc.setIdClient(jTextFieldIdClient.getText().trim());
                                        nc.setNom(jTextFieldNom.getText().trim());
    				    nc.setPrenom(jTextFieldPrenom.getText().trim());
    				    nc.setAdresse(jTextFieldAdresse.getText().trim());
    				    nc.setCodePostal(jTextFieldCp.getText().trim());
    				    nc.setCivilite((String)jComboBoxCivilite.getSelectedItem());
    				    nc.setVille(jTextFieldVille.getText().trim());
    				    nc.setTel(jTextFieldTel.getText().trim());
    				    nc.setFax(jTextFieldFax.getText().trim());
    				    nc.setMail(jTextFieldMail.getText().trim());
     
    				    new BaseDonnees(nc); 
                                        BdSelection bd = new BdSelection();
                                        bd.refresh();
     
                                        dispose();
     
    				}
    			});
    		}
    		return jButton;
    	}
    ........
    .......
     
    }
    Classe qui insère les données dans la base:

    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
     
    public class BaseDonnees  {
     
    	private String url ;
     
    	public BaseDonnees (NouveauClient nClient) 
    	{
                try 
                {
                    try 
                    {
                        Class.forName("com.mysql.jdbc.Driver");
                    } 
                    catch (ClassNotFoundException ex) 
                    {
                        Logger.getLogger(BaseDonnees.class.getName()).log(Level.SEVERE, null, ex);
                    }
                url ="jdbc:mysql://localhost:3306/gestion_stock";   
                System.out.println("connection réussie à* la BaseDonnees");
                Connection connection = DriverManager.getConnection(url, "root", "");
     
                Statement stmt = connection.createStatement();
     
                String sql = "INSERT INTO client (Id, Civilité, Nom, Prénom, Adresse, Code_postal, Ville, Téléphone, Fax, Mail) " +
                "VALUES ("+
                "'"+nClient.getIdClient()+"'," 
                +"'"+nClient.getCivilite()+"',"
                +"'"+nClient.getNom()+"'," 
                +"'"+nClient.getPrenom() +"',"
                +"'"+nClient.getAdresse()+ "',"
                +"'"+nClient.getCodePostal() + "',"
                +"'"+nClient.getVille()+ "',"
                +"'"+nClient.getTel()+"',"
                +"'"+nClient.getFax()+"',"
                +"'"+nClient.getMail()+"'"+")";
     
                System.out.println("Insertion dans la base ++++++++++++++");  
                 stmt.executeUpdate(sql);
                    } 
                    catch (SQLException e) 
                    {
                    System.out.println(e.getMessage());
                    System.out.println(e.getStackTrace());
                    }
     
                    }//fin constructeur
     
    }
    Classe pour insérer les données dans la table

    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
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
     
    public class BdSelection extends AbstractTableModel implements TableModelListener
    {
        private static final long serialVersionUID = 1L;
        private static String url;
        private Vector data = new Vector();
        private Vector columnNames = new Vector  ();
        private JTable jTableClient;
     
     
        public BdSelection ()
        {
     
        try
        {
        try
        {
        Class.forName("com.mysql.jdbc.Driver");
        }
        catch (ClassNotFoundException ex)
        {
        //Logger.getLogger(BaseDonnees.class.getName()).log(Level.SEVERE, null, ex);
        }
        url ="jdbc:mysql://localhost:3306/gestion_stock";
        System.out.println("connection à la BdSelection");
     
        Connection connection = DriverManager.getConnection(url, "root", "");
        Statement stmt = connection.createStatement();
     
        String sql = "select * FROM client";
     
        //stmt = connection.createStatement();
        ResultSet rs = stmt.executeQuery(sql);
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();
     
        for (int i = 1; i <= columns; i++) {
                columnNames.addElement(md.getColumnName(i));
            }
        //  Get row data
     
        while (rs.next()) {
        Vector row = new Vector(columns);
     
        for (int i = 1; i <= columns; i++) {
        row.addElement(rs.getObject(i));
        }
     
        data.add(row);
        }
     
        rs.close();
        stmt.close();
     
     
        }
        catch (SQLException e)
        {
        System.out.println(e.getMessage());
        System.out.println(e.getStackTrace());
        }
     
        }//fin constructeur
     
        public void refresh (){
     
        try
        {
        try
        {
            Class.forName("com.mysql.jdbc.Driver");
        }
        catch (ClassNotFoundException ex)
        {
        //Logger.getLogger(BaseDonnees.class.getName()).log(Level.SEVERE, null, ex);
        }
        url ="jdbc:mysql://localhost:3306/gestion_stock";
     
     
        Connection connection = DriverManager.getConnection(url, "root", "");
        Statement stmt = connection.createStatement();
     
        String sql = "select * FROM client";
     
        ResultSet rs = stmt.executeQuery(sql);
        ResultSetMetaData md = rs.getMetaData();
        int columns = md.getColumnCount();
        System.out.println("A nouveau dans la BdSelection via la methode refresh()");
        for (int i = 1; i <= columns; i++) {
        columnNames.addElement(md.getColumnName(i));
        }
        //  Get row data
     
        while (rs.next()) {
        Vector row = new Vector(columns);
     
        for (int i = 1; i <= columns; i++) {
        row.addElement(rs.getObject(i));
        }
     
        data.add(row);
        System.out.println("donnees recuperees dans la methode refrsh : "+ data);
        fireTableRowsInserted(0, getRowCount()-1);
        }
     
        rs.close();
        stmt.close();
     
        }
        catch (SQLException e)
        {
        System.out.println(e.getMessage());
        System.out.println(e.getStackTrace());
        }
     
        }
     
        /*public void add (NouveauClient client){
        data.add(client);      
        fireTableRowsInserted(0, getRowCount()-1);
        System.out.println(data);
        }*/
        @Override
        public int getColumnCount() {
            return columnNames.size();
        }
     
        @Override
        public int getRowCount() {
            return data.size();
        }
     
        @Override
        public Object getValueAt(int row, int column) {
            Vector rowData = (Vector) data.elementAt(row);
            return rowData.elementAt(column);
        }
     
        @Override
        public String getColumnName(int idx) {
            return (String)columnNames.elementAt(idx);
        }
     
        @Override
        public boolean isCellEditable(int arg0, int arg1) {
            return true;
        }
        @SuppressWarnings("unchecked")
        @Override
        public void setValueAt(Object value, int row, int col) {
            /*data.setElementAt( value, (row*getColumnCount())+col);
            fireTableDataChanged();*/
            Vector dataRow = (Vector)data.elementAt(row);
            dataRow.setElementAt(value, col);
            fireTableCellUpdated(row, col);
        }
    }
    Merci d'avance à tous pour des propositions.

  9. #9
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 142
    Par défaut
    Change ton constructeur de AjouterNouveauClient en

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public AjouterNouveauClient (BeSelection model){
       [...Ce que tu fais d habitude...]
     
       /*Rajoute cet attribut à ta classe aussi ;) */
     
       this.bdSelectionModel = model;
     
    }
    Ainsi, ton actionPerformed devient:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public void actionPerformed(java.awt.event.ActionEvent e) {
     
     [...idem...]
      this.bdSelectionModel.refresh();                                    
      dispose();
     
    }

    Et donc quand tu affiche ton JDialog, tu l'appelles comme ça dans ta Frame principale:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new AjouterNouveauClient ((BdSelection) getJTableClient().getTableModel());
    C'est tout bon ?

  10. #10
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    142
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 142
    Par défaut
    Autre chose, dans le constructeur de BdSelection, enlève tout ton code, et appel plutôt la méthode refresh

Discussions similaires

  1. Mise à jour automatique JTable
    Par encours dans le forum Composants
    Réponses: 8
    Dernier message: 30/08/2011, 11h49
  2. [PPT-2010] Mise à jour automatique PPSM à partir d'un fichier Excel
    Par frene dans le forum Powerpoint
    Réponses: 0
    Dernier message: 01/11/2010, 18h21
  3. Mise à jour automatique de champs à partir d'autres champs
    Par Heytabernak dans le forum Langage SQL
    Réponses: 1
    Dernier message: 17/10/2008, 14h56
  4. Réponses: 5
    Dernier message: 06/01/2005, 12h07
  5. Mise à jour automatique d'un JTextAera
    Par Vlakyron dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 25/09/2004, 20h11

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