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

EDT/SwingWorker Java Discussion :

Remplir JTexteField à partir de JCombobox


Sujet :

EDT/SwingWorker Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier Avatar de the watcher
    Inscrit en
    Juillet 2003
    Messages
    356
    Détails du profil
    Informations forums :
    Inscription : Juillet 2003
    Messages : 356
    Points : 123
    Points
    123
    Par défaut Remplir JTexteField à partir de JCombobox
    Bonjour les amis,

    Je cherche à mettre une procédure dans le ActionListener de ma combofournisseur afin d'afficher le numéro (NFOUFO) du fournisseur correspondant dans un Jtextfield lorsque je sélectionne (RSOCFO) le nom du fournisseur du combofournisseur.

    Voici le code qui rempli ma list:
    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
     
    	public DAOFourEtNumero(){
    	}
    	public static ArrayList<FourEtNumero> getlistFourEtNumero(){
    		connexion = new BDConnectAS400();
    		String requette  = "SELECT DISTINCT B33STFC.FTFOUL01.RSOCFO FROM B33STFC.FTFOUL01 ORDER BY RSOCFO ASC";
    		Statement state;
    		ResultSet res;
    		ArrayList<FourEtNumero> list = new ArrayList<FourEtNumero>();
    		try{
    			state = connexion.getInstance().createStatement();
    			res = state.executeQuery(requette);
    			while(res.next()){
    				FourEtNumero fourEtNum = new FourEtNumero();
                                    fourEtNum.setNFOUFO(res.getString(1));//Numéro du fournisseur
    				fourEtNum.setRSOCFO(res.getString(2));//raison sociale du fournisseur
     
    				list.add(fourEtNum);
    			}
    			res.close();
    			return list;
    		}catch (SQLException e){
    		}
    		return null;
    	}
    }
    Voici le code qui rempli Le combobox:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    		for(FourEtNumero comboFournisseur : list){
    			ComboFournisseur.addItem(comboFournisseur.getRSOCFO());
    			}
    Ma préoccupation est la suivante:quelle procédure dois-je mettre dans le ActionListener de ma combofournisseur afin afin lorque je sélection dans le combobox le nom (RSOCOFO) du fournisseur, son numéro (NFOUFO) correspondant apparaisse dans un Jtextfield.
    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
    public JComboBox getComboFournisseur() {
    		if (ComboFournisseur == null){
    			ComboFournisseur = new JComboBox();
    			ComboFournisseur.setBounds(135, 130, 352, 22);
    			ComboFournisseur.setSelectedIndex(-1);
    			//Action pour sélectionner le numéro du fournisseur
    			ComboFournisseur.addActionListener(new ActionListener() {
    				@Override
    				public void actionPerformed(ActionEvent e) {
    					// TODO Auto-generated method stub
    				le code ici...
    				}	
    				
    			});
    			
    		}
    		return ComboFournisseur;
    	}
    Merci encre les amis.
    L'important n'est pas de tout savoir mais de savoir où tout se trouve !

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 711
    Points : 4 797
    Points
    4 797
    Par défaut Perplexité
    Pour commencer, cette requête
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DISTINCT B33STFC.FTFOUL01.RSOCFO 
    FROM B33STFC.FTFOUL01 
    ORDER BY RSOCFO ASC
    ne renvoie qu'une seule colonne ; alors que le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    fourEtNum.setNFOUFO(res.getString(1));//Numéro du fournisseur
    fourEtNum.setRSOCFO(res.getString(2));//raison sociale du fournisseur
    s'adresse à 2 colonnes ...
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  3. #3
    Membre régulier Avatar de the watcher
    Inscrit en
    Juillet 2003
    Messages
    356
    Détails du profil
    Informations forums :
    Inscription : Juillet 2003
    Messages : 356
    Points : 123
    Points
    123
    Par défaut
    Désolé, j'ai dû malencontreusement supprimer la ligne sinon voici le code utilisé dans le projet:
    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
    public DAOFourEtNumero(){
    	}
    	public static ArrayList<FourEtNumero> getlistFourEtNumero(){
    		connexion = new BDConnectAS400();
    		String requette  = "SELECT DISTINCT NFOUFO,RSOCFO FROM B33STFC.FTFOUL01 ORDER BY RSOCFO ASC";
    		Statement state;
    		ResultSet res;
    		ArrayList<FourEtNumero> list = new ArrayList<FourEtNumero>();
    		try{
    			state = connexion.getInstance().createStatement();
    			res = state.executeQuery(requette);
    			while(res.next()){
    				FourEtNumero fourEtNum = new FourEtNumero();
    				fourEtNum.setNFOUFO(res.getString(1));//Numéro du fournisseur
    				fourEtNum.setRSOCFO(res.getString(2));//raison sociale du fournisseur
    			list.add(fourEtNum);
    			}
    			res.close();
    			return list;
    		}catch (SQLException e){
    		}
    	return null;
    	}
    Merci encore pour votre aide.
    L'important n'est pas de tout savoir mais de savoir où tout se trouve !

  4. #4
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 711
    Points : 4 797
    Points
    4 797
    Par défaut
    Globalement, le problème est d'afficher la raison sociale du fournisseur
    une fois qu'on aura choisi son code dans la ComboFournisseur.

    Je ferais comme suit :
    1) construire la ComboFournisseur comme décrit dans le code
    mais au lieu de stocker les valeurs dans une list, utiliser une map.
    On aura donc une sorte de tableau indexé à deux colonnes :
    - le code qui nous servira de clé
    - la raison sociale du fournisseur qui nous servira de valeur
    2) ActionListener va se déclencher quand on aura choisi le code du fournisseur.
    3) récupérer la valeur choisie dans la ComboFournisseur (c'est la clé)
    4) rechercher cette clé dans la map (voir doc de la map)
    5) une fois cette valeur clé trouvée, écrire la valeur de la map (cad la raison sociale du fournisseur) dans le JTextField

    Il est clair que la liste des fournisseurs ne doit pas comporter des milliers de lignes
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  5. #5
    Membre régulier Avatar de the watcher
    Inscrit en
    Juillet 2003
    Messages
    356
    Détails du profil
    Informations forums :
    Inscription : Juillet 2003
    Messages : 356
    Points : 123
    Points
    123
    Par défaut
    Merci encore Népomucène,

    Sans vouloir trop te demander est-ce possible d'avoir un exemple car j'ai entendu parler des hashMap mais je ne l'ai jamais utilisé ?
    L'important n'est pas de tout savoir mais de savoir où tout se trouve !

  6. #6
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 711
    Points : 4 797
    Points
    4 797
    Par défaut
    En effet : L'important n'est pas de tout savoir mais de savoir où tout se trouve !
    http://java.developpez.com/faq/java/...TIONS_info_map

    ... ne jamais hésiter à regarder dans la FAQ
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/02/2013, 22h31
  2. Remplir champ à partir de dates
    Par kgb1917 dans le forum VBA Access
    Réponses: 13
    Dernier message: 29/10/2007, 11h49
  3. remplir datagrid à partir de fichier xml
    Par wajdiisi2007 dans le forum VB 6 et antérieur
    Réponses: 0
    Dernier message: 10/08/2007, 12h27
  4. Réponses: 4
    Dernier message: 01/06/2007, 13h54
  5. remplir dataset à partir base propriétaire
    Par bib34690 dans le forum Windows Forms
    Réponses: 13
    Dernier message: 03/05/2007, 18h49

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