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 :

Problème rafraichissement JTable/DefaultTableModel


Sujet :

Composants Java

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2015
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2015
    Messages : 19
    Points : 15
    Points
    15
    Par défaut Problème rafraichissement JTable/DefaultTableModel
    Bonjour à tous,

    Je viens vers vous car je me trouve dans une impasse totale, je dois mettre à jour une JTable liée à un defaulttablemodel après une mise à jour de base de données.
    Pour ce faire j'utilise le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
            entryList.put( logBookObject.getId(), logBookObject );
            int row = getIndexWithObjectId( logBookObject.getId() );
     
            tableModel.setValueAt( logBookObject.getFormattedDate(), row, 0 );
            tableModel.setValueAt( logBookObject.getNomOP(), row, 1 );
            tableModel.setValueAt( logBookObject.getTypeTest(), row, 2 );
     
            tableModel.fireTableDataChanged();
    Les valeurs retournées par l'objet "logBookObject" sont les bonnes puisque lorsque je redémarre l'application les valeurs de la JTable sont bien mises à jour.

    Merci d'avance de vos réponses.

    Cordialement,

    Marc

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Normalement, ça devrait fonctionner. Tu n'est même pas obligé de faire le fire (c'est déjà fait par l'implémentation de DefaultTableModel, et c'est d'ailleurs un fireTableCellUpdated() - dans ton cas, s'il t'avait fallu le faire, un fireTableRowsUpdated aurait été mieux).

    Comment la JTable et le modèle sont-ils liés ? Tu as créé un DefaultTableModel et tu as créé ta JTable en lui passant ce modèle en paramètre, ou tu as récupéré le TableModel créé par défaut par la JTable ?
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2015
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2015
    Messages : 19
    Points : 15
    Points
    15
    Par défaut
    Bonjour Joel.drigo,

    Tout d'abord merci de votre réponse, j'ai pris note concernant le "fireTableRowsUpdated".
    En fait je crée directement une JTable dans ma vue et un DefaultTableModel dans mon autre classe logbook et pour l'instancier je fais la manipulation suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    logBookTable = new JTable( LogBook.getLogBook().getTableModel() );

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    On peut voir le code de la méthode getTableModel() ?
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2015
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2015
    Messages : 19
    Points : 15
    Points
    15
    Par défaut
    Voici le code de la méthode getableModel pour information car j'ai réussi à résoudre mon problème, il venait du fait que dans la méthode qui permettait de mettre à jour la table, la valeur de ma ligne retournée se trouvait toujours à 0 d’où le non rafraichissement immédiat mais une fois redémarré les données étant en base la jtable se rafraichissait bien. Je lui ai donc passé le bon numéro de ligne et tout est revenu dans l'ordre. Encore merci pour votre aide.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    public DefaultTableModel getTableModel()
        {
            return tableModel;
        }
    Cordialement,

    Marc

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

Discussions similaires

  1. JTable, problème rafraichissement
    Par Remox dans le forum Composants
    Réponses: 1
    Dernier message: 03/01/2013, 15h07
  2. Problème rafraichissement JTable
    Par david64 dans le forum Agents de placement/Fenêtres
    Réponses: 1
    Dernier message: 18/05/2010, 10h23
  3. Problèmes de rafraichissement JTable avec un TableModel
    Par LestoK dans le forum Composants
    Réponses: 3
    Dernier message: 10/04/2009, 14h37
  4. [débutant] rafraichissement JTable + action bouton
    Par sqwam71 dans le forum Composants
    Réponses: 4
    Dernier message: 28/12/2005, 15h29
  5. [Jtable] DefaultTableModel renderer des boolean
    Par lilou77 dans le forum Composants
    Réponses: 2
    Dernier message: 20/12/2005, 15h32

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