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 :

JTable


Sujet :

Composants Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 42
    Par défaut JTable
    Bonjour,

    je suis débutant en JTable et j'ai un gros problème.
    J'aimerais afficher des statiques provenant d'une base de donnée SQL, dans une JTable, qui se trouve dans un panel.

    Voici le 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
    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
     package resto;
     
    import java.awt.*;
    import java.awt.event.*;
    import javax.swing.*;
    import javax.swing.event.*;
    import java.util.*;
    import java.sql.*;
     
     
    public class JPStat extends JPanel {
        private Fenetre fenetre;
        private JButton jbRetour;
        private JPanel jpanBoutonBas, jpanStat;
        private String Nom, Plat;
        private JTable jtStat;
        private Connection connec;
        private String requete1="SELECT * FROM employe WHERE nom";
        private String requete2="SELECT * FROM plat WHERE nom";
        private JComboBox jcbStat;
     
     
     
        public JPStat(Fenetre fensave) {
            this.setLayout(new BorderLayout());
            fenetre=fensave;
            String[] contenu={"Sélectionner ici","Voir utilisateur","Voir repas"};
            MonGestionnaireAction ga = new MonGestionnaireAction();
            MonGestionnaire2 g= new MonGestionnaire2();
            jcbStat= new JComboBox(contenu);
            jpanStat = new JPanel();
            jpanBoutonBas = new JPanel();
     
            jcbStat.addItemListener(ga);
     
            jcbStat.addItemListener(ga);
            jpanStat.add(jcbStat);
     
     
            jbRetour = new JButton ("Retour");
            jbRetour.addActionListener(g);
            jpanBoutonBas.add(jbRetour);
            this.add(jpanStat,BorderLayout.NORTH);
            this.add(jpanBoutonBas,BorderLayout.SOUTH);
        }
         private class MonGestionnaire2 implements ActionListener
                {
                     public void actionPerformed(ActionEvent f){
     
     
                   if (f.getSource()==jbRetour){
                   fenetre.getContain().removeAll() ;
                   PanelAdmin pA= new PanelAdmin(fenetre);
                   fenetre.getContain().add(pA,BorderLayout.CENTER);
                   fenetre.getContain().repaint();
                   fenetre.setVisible(true);
     
                   fenetre.setFalseJMIStatistic();
                           }
     
                   }
     
               }
         private class MonGestionnaireAction implements ItemListener
      {
              public void itemStateChanged(ItemEvent s){
                fenetre.getConnec();
                  switch(jcbStat.getSelectedIndex())
                  { case 0:if(s.getStateChange()==ItemEvent.SELECTED)
                       JOptionPane.showMessageDialog(null,"A vous de choisir");
     
                  break;
                  case 1: if(s.getStateChange()==ItemEvent.SELECTED){
                                  try{
     
                    jtStat= new JTable(AccesGen.creerTableModel(connec, requete1));
     }
                   catch(SQLException sq){
                   JOptionPane.showMessageDialog(null,"Erreur","Erreur",JOptionPane.ERROR_MESSAGE);
                   }
     
                  removeAll();
                                  jtStat.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
                   JScrollPane defilant = new JScrollPane(jtStat);
                   jpanStat.add(jtStat);
                   jpanStat.add(defilant);
                     repaint();              
                  }
                  break;
                      case 2 : if(s.getStateChange()==ItemEvent.SELECTED){ 
                          try{
     
                              jtStat= new JTable(AccesGen.creerTableModel(connec, requete2));
                          }
     
                   catch(SQLException sq){
                   JOptionPane.showMessageDialog(null,"Erreur","Erreur",JOptionPane.ERROR_MESSAGE);
                   }
                          removeAll();
     
                   jtStat.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
                   JScrollPane defilant = new JScrollPane(jtStat);
                   jpanStat.add(defilant);
                   jpanStat.add(jtStat);
                   repaint();
                      }
          break;
     
     
                    }
              }
     
     
     
     
     
    }}
    Il me donne plein d'erreurs, je sais pas si cela vaut la peine que je les indique, du moins celles-cis se produisent lorsque j'appuye sur une des listes de ma jcombobox

    Merci à vous tous,

    Flames

  2. #2
    Expert confirmé

    Profil pro
    Fabricant et casseur d'avions
    Inscrit en
    Avril 2004
    Messages
    3 817
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Fabricant et casseur d'avions
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2004
    Messages : 3 817
    Par défaut
    Salut,

    Citation Envoyé par flames
    Il me donne plein d'erreurs, je sais pas si cela vaut la peine que je les indique,
    ben... disons que si tu veux qu'on t'aide à les résoudre, ça pourrait aider... à moins que tu veuilles le faire tout seul et ne pas partager tes soucis avec nous... (et surtout, j'ai le flemme de mettre ton code dans mon netbeans...) (surtout présenté comme ça... faudra mettre ton code entre balises [ code ] la prochaine fois, c'est plus mieux... ... avec le bouton avec un "#" dessus...)

    Messages d'erreur complets tant qu'à faire, avec numéro de ligne et tout et tout...

    Merci...
    "Errare humanum est, sed perseverare diabolicum"

    Ma page sur DVP.com

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 42
    Par défaut
    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
     
     
    package resto;
     
    import java.awt.*;
    import java.awt.event.*;
    import javax.swing.*;
    import javax.swing.event.*;
    import java.util.*;
    import java.sql.*;
     
     
    public class JPStat extends JPanel {
    private Fenetre fenetre;
    private JButton jbRetour;
    private JPanel jpanBoutonBas, jpanStat;
    private String Nom, Plat;
    private JTable jtStat;
    private Connection connec;
    private String requete1="SELECT * FROM employe WHERE nom";
    private String requete2="SELECT * FROM plat WHERE nom";
    private JComboBox jcbStat;
     
     
     
    public JPStat(Fenetre fensave) {
    this.setLayout(new BorderLayout());
    fenetre=fensave;
    String[] contenu={"Sélectionner ici","Voir utilisateur","Voir repas"};
    MonGestionnaireAction ga = new MonGestionnaireAction();
    MonGestionnaire2 g= new MonGestionnaire2();
    jcbStat= new JComboBox(contenu);
    jpanStat = new JPanel();
    jpanBoutonBas = new JPanel();
     
    jcbStat.addItemListener(ga);
     
    jcbStat.addItemListener(ga);
    jpanStat.add(jcbStat);
     
     
    jbRetour = new JButton ("Retour");
    jbRetour.addActionListener(g);
    jpanBoutonBas.add(jbRetour);
    this.add(jpanStat,BorderLayout.NORTH);
    this.add(jpanBoutonBas,BorderLayout.SOUTH);
    }
    private class MonGestionnaire2 implements ActionListener
    {
    public void actionPerformed(ActionEvent f){
     
     
    if (f.getSource()==jbRetour){
    fenetre.getContain().removeAll() ;
    PanelAdmin pA= new PanelAdmin(fenetre);
    fenetre.getContain().add(pA,BorderLayout.CENTER);
    fenetre.getContain().repaint();
    fenetre.setVisible(true);
     
    fenetre.setFalseJMIStatistic();
    }
     
    }
     
    }
    private class MonGestionnaireAction implements ItemListener
    {
    public void itemStateChanged(ItemEvent s){
    fenetre.getConnec();
    switch(jcbStat.getSelectedIndex())
    { case 0:if(s.getStateChange()==ItemEvent.SELECTED)
    JOptionPane.showMessageDialog(null,"A vous de choisir");
     
    break;
    case 1: if(s.getStateChange()==ItemEvent.SELECTED){
    try{
     
    jtStat= new JTable(AccesGen.creerTableModel(connec, requete1));
    }
    catch(SQLException sq){
    JOptionPane.showMessageDialog(null,"Erreur","Erreur",JOptionPane.ERROR_MESSAGE);
    }
     
    removeAll();
    jtStat.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
    JScrollPane defilant = new JScrollPane(jtStat);
    jpanStat.add(jtStat);
    jpanStat.add(defilant);
    repaint(); 
    }
    break;
    case 2 : if(s.getStateChange()==ItemEvent.SELECTED){ 
    try{
     
    jtStat= new JTable(AccesGen.creerTableModel(connec, requete2));
    }
     
    catch(SQLException sq){
    JOptionPane.showMessageDialog(null,"Erreur","Erreur",JOptionPane.ERROR_MESSAGE);
    }
    removeAll();
     
    jtStat.setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
    JScrollPane defilant = new JScrollPane(jtStat);
    jpanStat.add(defilant);
    jpanStat.add(jtStat);
    repaint();
    }
    break;
     
     
    }
    }
     
     
    }}
    Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
    at resto.AccesGen.creerTableModel(AccesGen.java:34)
    at resto.JPStat$MonGestionnaireAction.itemStateChanged(JPStat.java:76)
    at javax.swing.JComboBox.fireItemStateChanged(JComboBox.java:1162)
    at javax.swing.JComboBox.selectedItemChanged(JComboBox.java:1219)
    at javax.swing.JComboBox.contentsChanged(JComboBox.java:1266)
    at javax.swing.AbstractListModel.fireContentsChanged(AbstractListModel.java:100)
    at javax.swing.DefaultComboBoxModel.setSelectedItem(DefaultComboBoxModel.java:88)
    at javax.swing.JComboBox.setSelectedItem(JComboBox.java:551)
    at javax.swing.JComboBox.setSelectedIndex(JComboBox.java:597)
    at javax.swing.plaf.basic.BasicComboPopup$Handler.mouseReleased(BasicComboPopup.java:808)
    at java.awt.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:232)
    at java.awt.Component.processMouseEvent(Component.java:5488)
    at javax.swing.JComponent.processMouseEvent(JComponent.java:3126)
    at javax.swing.plaf.basic.BasicComboPopup$1.processMouseEvent(BasicComboPopup.java:476)
    at java.awt.Component.processEvent(Component.java:5253)
    at java.awt.Container.processEvent(Container.java:1966)
    at java.awt.Component.dispatchEventImpl(Component.java:3955)
    at java.awt.Container.dispatchEventImpl(Container.java:2024)
    at java.awt.Component.dispatchEvent(Component.java:3803)
    at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4212)
    at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3892)
    at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3822)
    at java.awt.Container.dispatchEventImpl(Container.java:2010)
    at java.awt.Window.dispatchEventImpl(Window.java:1774)
    at java.awt.Component.dispatchEvent(Component.java:3803)
    at java.awt.EventQueue.dispatchEvent(EventQueue.java:463)
    at java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.java:242)
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:163)
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:157)
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:149)
    at java.awt.EventDispatchThread.run(EventDispatchThread.java:110)


    Voilà mais ça parait tellement énorme
    Voici toujours la classe AccesGen:

    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
     
    package resto;
    import java.awt.*;	
    import java.awt.event.*;
    import javax.swing.*;
    import java.sql.*;
    import java.util.*;
     
    public class AccesGen 
    {
        public static Connection connecter (String bd, String user, String pass)
                   					               throws SQLException
        	{Connection connexion = null;
           try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
                    connexion = DriverManager.getConnection("jdbc:odbc:"+bd,user,pass);}
           catch (ClassNotFoundException ex)
                 {ex.printStackTrace( );}
        	  return connexion;
        	 }
     
        public static void deconnecter (Connection connec)  throws SQLException
          {connec.close( ); }
     
     
        public static int executerInstruction (Connection connec,String instruction) 
                    						   throws SQLException
        	{Statement requete = connec.createStatement( );
         	 int nbIns = requete.executeUpdate(instruction);
         	 return nbIns;
        	}
     
     
        public static MyTableModel creerTableModel (Connection connec, String requete)
             							   throws SQLException
        {Statement stat = connec.createStatement( );
          ResultSet donnees = stat.executeQuery(requete); 
          Vector nomColonnes = creerVectorNomColonnes(donnees);
          Vector lignes = creerVectorLignes(donnees);
          Vector objetTypes = creerObjetTypes(donnees);
          MyTableModel model = new MyTableModel(nomColonnes,lignes, objetTypes);
          return model;   
        }
     
     
        public static Vector creerVectorNomColonnes (ResultSet donnees) throws SQLException
           {ResultSetMetaData meta = donnees.getMetaData( );
             Vector nomColonnes = new Vector( );    
     
             for (int i = 1; i <= meta.getColumnCount( );i++)
           		{ nomColonnes.addElement(meta.getColumnName(i));}    
            return nomColonnes; }
       public static Vector creerVectorLignes (ResultSet donnees)  throws SQLException
          {ResultSetMetaData meta = donnees.getMetaData( );    
           Vector nomColonnes = new Vector( );
           Vector lignes = new Vector( );
     
           while (donnees.next( ))
              {lignes.addElement(getNextRow(donnees,meta)); }
     
           return lignes ;}
     
     
        private static Vector getNextRow (ResultSet donnees, ResultSetMetaData meta)
              								  throws SQLException
        {Vector ligneCourante = new Vector( );
         String stringLu;
         int entierLu;
         double doubleLu;
         boolean booleenLu;
         java.util.Date dateLue;
     
         for (int i = 1; i <= meta.getColumnCount( );i++)
         {switch (meta.getColumnType(i))
          {case Types.VARCHAR:  stringLu = donnees.getString(i);
                			ligneCourante.addElement(donnees.wasNull( )?null:stringLu);
                			break;
           case Types.CHAR:  stringLu = donnees.getString(i);
               			    ligneCourante.addElement(donnees.wasNull( )?null:stringLu);
                		    break;
           case Types.INTEGER:  entierLu = donnees.getInt(i);
               		 ligneCourante.addElement(donnees.wasNull( )?null:new Integer(entierLu));
                	 break;
           case Types.DOUBLE: doubleLu = donnees.getDouble(i);
                	ligneCourante.addElement(donnees.wasNull( )?null:new Double(doubleLu));
                	break;
           case Types.TIMESTAMP: dateLue = donnees.getDate(i);
               				   ligneCourante.addElement(donnees.wasNull( )?null:dateLue);
                			   break;  
          case Types.BIT:  booleenLu = donnees.getBoolean(i);
                          ligneCourante.addElement(donnees.wasNull( )?null:new Boolean(booleenLu));
                          break;          
          }
         }
         return ligneCourante;
        }
     
     
        private static Vector creerObjetTypes(ResultSet donnees)  throws SQLException
        {ResultSetMetaData meta = donnees.getMetaData();    
         Vector objetTypes = new Vector( );
         String stringLu = "bidon";
         int entierLu = 1;
         double doubleLu = 1.0;
         boolean booleenLu = true;
         java.util.Date dateLue = new java.util.Date( );
     
         for (int i = 1; i <= meta.getColumnCount( );i++)
         {switch (meta.getColumnType(i))
          {case Types.VARCHAR:  objetTypes.addElement(stringLu);       		   break;
           case Types.CHAR:     	  objetTypes.addElement(stringLu);			   break;
           case Types.INTEGER: 	  objetTypes.addElement(new Integer(entierLu)); 	   break;
           case Types.DOUBLE: 	  objetTypes.addElement(new Double(doubleLu));    break;
           case Types.TIMESTAMP: objetTypes.addElement(dateLue); 		   break;  
          case Types.BIT: 		 objetTypes.addElement(new Boolean(booleenLu));  break;          
          }
         }
         return objetTypes;
        }
     
     
        public static Vector creerVecteur1Colonne(Connection connec, String requete)
                								 throws SQLException
        {Statement stat = connec.createStatement( );
         ResultSet donnees = stat.executeQuery(requete); 
         ResultSetMetaData meta = donnees.getMetaData( );    
         Vector uneColonne = new Vector( );
         String stringLu;
         int entierLu;
         double doubleLu;
         boolean booleenLu;
         java.util.Date dateLue;
     
         while (donnees.next( ))
         {switch (meta.getColumnType(1))
          {case Types.VARCHAR:	stringLu = donnees.getString(1);
                          uneColonne.addElement(donnees.wasNull()?null:stringLu);		           break;
           case Types.CHAR:		stringLu = donnees.getString(1);
                          uneColonne.addElement(donnees.wasNull()?null:stringLu);		           break;
           case Types.INTEGER:		entierLu = donnees.getInt(1);
                       uneColonne.addElement(donnees.wasNull()?null:new Integer(entierLu));    break;
           case Types.DOUBLE:		doubleLu = donnees.getDouble(1);
                       uneColonne.addElement(donnees.wasNull()?null:new Double(doubleLu));  break;
           case Types.TIMESTAMP:	dateLue = donnees.getDate(1);
                       uneColonne.addElement(donnees.wasNull()?null:dateLue) ;	 	           break;  
          case Types.BIT:			booleenLu = donnees.getBoolean(1);
                    uneColonne.addElement(donnees.wasNull()?null:new Boolean(booleenLu));  break;          
          }
         }
         return uneColonne ;
        }
     }

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 42
    Par défaut
    La première erreur vient de ceci :

    Statement stat = connec.createStatement( );

    de la classe accesGen


    NB: je travaille avec netBeans

  5. #5
    Expert confirmé

    Profil pro
    Fabricant et casseur d'avions
    Inscrit en
    Avril 2004
    Messages
    3 817
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Fabricant et casseur d'avions
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2004
    Messages : 3 817
    Par défaut
    Citation Envoyé par flames
    #
    Euh... j'ai dit le "bouton" avec un "#" dans l'interface graphique pour saisir les messages... ou des "balises" [ code ] (sans les espaces... si l'interface graphique est en mode texte...)...

    Pas la peine de mettre tout ton code, en général les lignes qui posent problèmes, avec quelques lignes avant pour savoir à quoi correspondent les objets en question, suffisent... là c'est illisible...

    J'essaie de trouver la ligne qui pose problème dans ce fouillis et je vois ensuite...
    "Errare humanum est, sed perseverare diabolicum"

    Ma page sur DVP.com

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 42
    Par défaut
    Voilà j'ai changé

  7. #7
    Expert confirmé

    Profil pro
    Fabricant et casseur d'avions
    Inscrit en
    Avril 2004
    Messages
    3 817
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : Fabricant et casseur d'avions
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2004
    Messages : 3 817
    Par défaut
    Aaaah! Ben c'est beaucoup mieux comme ça!

    Bon... tu passes un objet "connec" en paramètre de creerTableModel dans ton listener... mais je ne trouve nulle part d'initialisation de ce "connec". C'est ce qui explique le NullPointerException.

    A moins que je ne sois passé à travers...
    "Errare humanum est, sed perseverare diabolicum"

    Ma page sur DVP.com

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

Discussions similaires

  1. [Swing]JTable- Dimensionner les colonnes
    Par loutfi dans le forum Composants
    Réponses: 12
    Dernier message: 01/07/2011, 08h50
  2. focus dans une cellule d'une JTable
    Par coil dans le forum Composants
    Réponses: 5
    Dernier message: 07/07/2010, 17h15
  3. [SWING]jTable + Focus
    Par chady dans le forum Composants
    Réponses: 5
    Dernier message: 27/02/2003, 14h51
  4. JBuilder7 & JTable Colonne alignement
    Par Tonton Luc dans le forum JBuilder
    Réponses: 5
    Dernier message: 06/11/2002, 17h32
  5. Réponses: 9
    Dernier message: 12/08/2002, 07h38

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