Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : Raffraichissment d'une jtable a partir d'une base oracle [ Divers / Débutant(e) ] (amin666)

jeudi 17 avril 2008 à 03:17:25 | Raffraichissment d'une jtable a partir d'une base oracle

amin666

Salut a tous. voila que ca fait 2 jrs ke je galere avec ce prob..
je vous explique, je developpe une interface swing qui doit afficher des enregistrement d'une base oracle dans une jtable.
L'affichage doit s'effectuer suite a un action performed d'un boutton (pour pouvoir recuperer les criteres de la recherche dans une requete sql) et le raffraichissment de la jtable doit etre automatique (si de nouveaux enregistrement sont effectué au niveau de la base ils doivent etre affichés). La methode ke g developpé fonctionne correctement: elle recherche les enregistrement et raffraichit la table, ceci est faisable si cette methode est appelé ds le void main, mais si j l'appelle dans l'evenement action performed du boutton(pour pouvoir specifier les criteres de recherche) l'execution se bloque et j n recois mem pa d'erreur.
Merci

jeudi 17 avril 2008 à 09:40:19 | Re : Raffraichissment d'une jtable a partir d'une base oracle

Ombitious_Developper

Salut:

Le sujet est un peu vague.

Est ce que tu as utilisé DefaultTableModel ou bien tu as étendu la classe AbstractTableModel?

jeudi 17 avril 2008 à 17:14:20 | Re : Raffraichissment d'une jtable a partir d'une base oracle

amin666



Merci pr la reponse.
En fait j'ai crée un modele qui etends AbstractTableModel.voici un exemple qui illustre le probleme.

import javax.swing.SwingUtilities;
import java.awt.BorderLayout;
import javax.swing.JPanel;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import java.awt.Rectangle;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JButton;
import oracle.jdbc.pool.OracleDataSource;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

public class test extends JFrame {

    private static final long serialVersionUID = 1L;
    private JPanel jContentPane = null;
    private JScrollPane jScrollPane = null;
    private static JTable jTable = null;
    private static JButton jButton = null;
    private static String req="select * from emp"; 

    /**
     * This method initializes jScrollPane   
     *    
     * @return javax.swing.JScrollPane   
     */
    private JScrollPane getJScrollPane() {
        if (jScrollPane == null) {
            jScrollPane = new JScrollPane();
            jScrollPane.setBounds(new Rectangle(0, 80, 637, 84));
            jScrollPane.setViewportView(getJTable());
        }
        return jScrollPane;
    }

    /**
     * This method initializes jTable   
     *    
     * @return javax.swing.JTable   
     */
    private JTable getJTable() {
        if (jTable == null) {
            jTable = new JTable();
            jTable.setSize(new Dimension(581, 260));
        }
        return jTable;
    }

    /**
     * This method initializes jButton   
     *    
     * @return javax.swing.JButton   
     */
    private JButton getJButton() {
        if (jButton == null) {
            jButton = new JButton();
            jButton.setBounds(new Rectangle(99, 20, 91, 26));
            jButton.setText("Rechercher");
           
           
           
        }
        return jButton;
    }

//ici la methode qui effectue la recherche et le raffraichissement
    public static void rechercher(){
        try{
           
            Dbmanager d = new Dbmanager();  //Dbmanager est une classe qui contient les methode relatives a la base (connexion, execution des requete...)
             d.connect("database", "user", "password");
               MonTableModel m =new MonTableModel(d.ColNames(d.getQuery(req)),d.donnee(d.getQuery(req)));//MonTableModel  est la classe qui etends abstract table model
              jTable.setModel(m);
                 while(true){
                  m.majDonnees(d.donnee(d.getQuery(req)));
                                     
                               
                try {
             Thread.sleep(2000);
                  }catch(InterruptedException ie){}  
                           }
             }catch(Exception et){et.printStackTrace();}
    }

    public static void main(String[] args) {
        new test();
rechercher();// la methode placé ainsi ds la main fonctionnecorrectement mais elle fonctionne dés le demarrage de l'application et j n peu pa modifier les criteres de recherche
      
      
    }

    /**
     * This is the default constructor
     */
    public test() {
        super();
        initialize();
       
    }

   
    private void initialize() {
        this.setSize(300, 200);
        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        this.setContentPane(getJContentPane());
        this.setTitle("JFrame");
        this.setVisible(true);
               
    }

    /**
     * This method initializes jContentPane
     *
     * @return javax.swing.JPanel
     */
    private JPanel getJContentPane() {
        if (jContentPane == null) {
            jContentPane = new JPanel();
            jContentPane.setLayout(null);
            jContentPane.add(getJScrollPane(), null);
            jContentPane.add(getJButton(), null);
        }
        return jContentPane;
    }
}

Maintenant si j'elimine l'appel de la methode rechercher du main (et je suupprime l'attribut statique) et que je l'appelle dans un action performed du boutton jButton, l'execution se bloque et je n recoi mem pa de message d'erreur
Voici le code bloquant

.import javax.swing.SwingUtilities;
import java.awt.BorderLayout;
import javax.swing.JPanel;
import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import java.awt.Rectangle;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JButton;
import oracle.jdbc.pool.OracleDataSource;
import java.awt.Dimension;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

public class test extends JFrame {

    private static final long serialVersionUID = 1L;
    private JPanel jContentPane = null;
    private JScrollPane jScrollPane = null;
    private static JTable jTable = null;  //  @jve:decl-index=0:visual-constraint="10,220"
    private static JButton jButton = null;
    private static String req="select * from emp";  //  @jve:decl-index=0:
//private static boolean rech=false;
    /**
     * This method initializes jScrollPane   
     *    
     * @return javax.swing.JScrollPane   
     */
    private JScrollPane getJScrollPane() {
        if (jScrollPane == null) {
            jScrollPane = new JScrollPane();
            jScrollPane.setBounds(new Rectangle(0, 80, 637, 84));
            jScrollPane.setViewportView(getJTable());
        }
        return jScrollPane;
    }

    /**
     * This method initializes jTable   
     *    
     * @return javax.swing.JTable   
     */
    private JTable getJTable() {
        if (jTable == null) {
            jTable = new JTable();
            jTable.setSize(new Dimension(581, 260));
        }
        return jTable;
    }

    /**
     * This method initializes jButton   
     *    
     * @return javax.swing.JButton   
     */
    private JButton getJButton() {
        if (jButton == null) {
            jButton = new JButton();
            jButton.setBounds(new Rectangle(99, 20, 91, 26));
            jButton.setText("Rechercher");
            jButton.addActionListener(new java.awt.event.ActionListener() {
                public void actionPerformed(java.awt.event.ActionEvent e) {
req="select ename from emp"    ;
rechercher();} // ajout d'un action performed qui me permet d'afficher la jtable suivant un nouveau critere de recherche et empeche la recherche des le demarrage de l'application
            });
           
           
           
        }
        return jButton;
    }


    public void rechercher(){
        try{
           
            Dbmanager d = new Dbmanager();
             d.connect("pfe", "sysman", "password");
               MonTableModel m =new MonTableModel(d.ColNames(d.getQuery(req)),d.donnee(d.getQuery(req)));
              jTable.setModel(m);
                 while(true){
                  m.majDonnees(d.donnee(d.getQuery(req)));
                                     
                               
                try {
             Thread.sleep(2000);
                  }catch(InterruptedException ie){}  
                           }
             }catch(Exception et){et.printStackTrace();}
    }
    public static void main(String[] args) {
        new test();
      
      
    }

    /**
     * This is the default constructor
     */
    public test() {
        super();
        initialize();
       
    }

   
    private void initialize() {
        this.setSize(300, 200);
        this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        this.setContentPane(getJContentPane());
        this.setTitle("JFrame");
        this.setVisible(true);
       
       
    }

    /**
     * This method initializes jContentPane
     *
     * @return javax.swing.JPanel
     */
    private JPanel getJContentPane() {
        if (jContentPane == null) {
            jContentPane = new JPanel();
            jContentPane.setLayout(null);
            jContentPane.add(getJScrollPane(), null);
            jContentPane.add(getJButton(), null);
        }
        return jContentPane;
    }

   

}

J'espere que j vous ai eclairci le prob, merci encore
Crdlt




vendredi 18 avril 2008 à 06:14:06 | Re : Raffraichissment d'une jtable a partir d'une base oracle

amin666

Réponse acceptée !
Le probleme est résolu.C'eait une betise dans le threading.
Le conflit residait dans le thread du main qui ne gerait pa le raffraichissement.
La solution est de creer une classe qui etend Thread et d'implementer le raffraichissement ds la fonction run(); et puis faire appel a ce thread ds le ActionPerformed du boutton.




Cette discussion est classé dans : base, enregistrement, jtable, oracle, raffraichissment


Répondre à ce message

Sujets en rapport avec ce message

Oracle et JDBC, Enregistrement [ par perrotju ] Voila mon problème : dans ma base de données Oracle, j'ai créé une table dans laquelle j'ai inséré une séquence, séquence rattachée à un champ (identi Pb affichage d'une ligne dans une JTable [ par Onclickert ] Salut à tous,Dans mon panel, j'ai une JTable avec une Scroll barre. On ne peut voir que 4 enregistrements de ma JTable. Or ma JTable contient 10 enreg JTable liée à une table de ma base [ par nouroudiop ] Salut les gars,j'aimerais savoir comment on arrive à lier une JTable directement à une table de ma base pour pouvoir effectuer directement une mise à BASE LOCALE.... JDBC Comment faire? [ par darktonight ] Voilà j'ai suivi comme beaucoup d'exemple le montre un test de connection, mon fichier data.properties est de la forme :jdbc.drivers=oracle.jdbc.drive Base de données : enregistrement en masse [ par fabrice_pi ] Bonjour,J'aimerais réduire le temps de stockage d'informations dans une base de données. Je veux toujours stocker le même format d'information : j'uti Pilote JDBC [ par chichoux ] Voila, je me suis mis au JDBC puisque je souhaiterais lier le JAVA et ma base de données ORACLE. Pour cela , il me faut utiliser JDBC; or dès le débu chargement du driver [ par progrima ] Slt je developpe une applicaion sous javaBeans 4.0, j'essaye de me connecter à une base de donnée oracle et je n'arrive pas à le faire!!!j'ai un prob connexion jsp et oracle [ par aminix9 ] salu tt lmonde ,est c ke vous pouvez me donner ou bien m indiquer le code d une page JSP qui se connecte à une base de donnees oracle et affiche les i inserer et retirer des image d'une base oracle [ par stefane ] Bonsoir a tousje suis debutant en ajava et j'aimerai savoir comment inserer une image dans une  base oracle en utilisant le type BLOB pour stocker l'i


Nos sponsors

Sondage...

CalendriCode

Janvier 2009
LMMJVSD
   1234
567891011
12131415161718
19202122232425
262728293031 

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,234 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.