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 :

tableau de statistiques dans JTable


Sujet :

Composants Java

  1. #1
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut tableau de statistiques dans JTable
    je veux faire des statistiques sur ma BDD en java et avoir le résultat dans un JTable, alors j'ai créé la méthode suivante:
    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 String getStat(String table, String as, String champ,String condition,String group){
     
    		try {
    			String nbr = "";
    			String query = "SELECT COUNT(*) FROM "+table+" AS "+as+" WHERE "+champ+"='"+condition+"' GROUP BY "+group;
    			stat = cnx.prepareStatement(query);
    			rslt = stat.executeQuery();
    			if(rslt.next()){
    				nbr = rslt.getString(as);
    			}
    			return nbr;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return e.getMessage();
    		}
    	}
    pour visualiser le résultat j'ai dessiné un tableau tableFil, mais je veux que mon tableau affiche pour chaque filière le nombre des filles et garçons
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    JButton btnStat = new JButton("Générer Statistiques");
    		btnStat.addActionListener(new ActionListener() {
    			public void actionPerformed(ActionEvent e) {
    				sql.getStat("etudiant", "Garçons", "genre", "M", "code_f");
    				tableFil.setModel(DbUtils.resultSetToTableModel(rslt));
    			}
    		});
    mais mon code génère plusieurs erreurs, comme: Column 'genre' not found.
    je ne sais comment régler celà ??

  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,

    Le message d'erreur dit que tu n'as pas de colonne appelée genre dans ta table etudiant. Il y'en a une ou pas ?

    Par ailleurs

    1. Je doute que count(*) soit un String ! Ce serait plutôt un int, non ?
    2. Dans l'actionListener, tu ne récupères pas le résultat de l'appel de getStat(). Mais peut-être cet appel ne sert-il qu'à affecter le rslt utilisé en argument dans DbUtils.resultSetToTableModel(rslt) ? Pourquoi ne pas faire plus simplement et proprement que la méthode retourne le TableModel ?
    3. Tu ne fermes ni statement, ni resultset ! En plus, les variables semblent être déclarées en variable de classe : à chaque appel, on perd les précédentes instances qui ne seront jamais fermées sauf à la fermeture de la connexion. Un bon moyen d'avoir de la consommation mémoire inutile.
    4. ça sert à quoi d'utiliser un preparedStatement pour n'utiliser que des paramètres en dur ? Utilise les paramètres !
    5. A quoi sert l'alias dans ta requête ?
    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 habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    le champ genre existe dans ma table etudiant, avant j'ai mis le type int mais ça donne trop d'erreurs

  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
    Et c'est quoi les autres erreurs ?

    Par ailleurs, je n'avais pas vu, mais nbr = rslt.getString(as);, ça ne risque pas de fonctionner : la variable as c'est l'alias de table, alors que c'est un nom de champ qu'il faut comme argument. Mais tu voulais peut-être en faire un alias pour count(*), comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query = "SELECT COUNT(*) AS " + as + " FROM "+table + " WHERE "+champ+"='"+condition+"' GROUP BY "+group;
    Par ailleurs, cet alias est inutile : tu peux aussi récupérer la valeur par nbr = rslt.getString( 1 );
    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 habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    en faite je reconnais que ma fonction getStat() est fausse car là le résultat n'est pas un entier mais un tableau car il va m'afficher selon chaque group by le nombre qui lui correspond alors je ne sais comment procéder

  6. #6
    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
    Bah, tout simplement comme je te l'ai indiqué :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    public TableModel getStat(String table, String as, String champ,String condition,String group){
     
    		try { 
    			String query = "SELECT COUNT(*) FROM "+table+" AS "+as+" WHERE "+champ+"='"+condition+"' GROUP BY "+group;
    			stat = cnx.prepareStatement(query);
    			rslt = stat.executeQuery();
                            return DbUtils.resultSetToTableModel(rslt); 
    		} catch (Exception e) {
    			e.printStackTrace();
    			return new DefaultTableModel();
    		}
    	}
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    JButton btnStat = new JButton("Générer Statistiques");
    		btnStat.addActionListener(new ActionListener() {
    			public void actionPerformed(ActionEvent e) {
    				tableFil.setModel(getStat("etudiant", "Garçons", "genre", "M", "code_f"));
    			}
    		});
    Bon, ça c'est avec le minimum de modifications de ton code, mais il faudrait au moins fermer le Statement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    public TableModel getStat(String table, String as, String champ,String condition,String group){
     
    		try (PreparedStatement statement = cnx.prepareStatement( "SELECT COUNT(*) FROM "+table+" WHERE "+champ+"=? GROUP BY "+group) ) { 
    			statement.setString(1, condition); 
                            return DbUtils.resultSetToTableModel(stat.executeQuery()); 
    		} catch (Exception e) {
    			e.printStackTrace();
    			return new DefaultTableModel();
    		}
    	}
    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.

  7. #7
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    merci ceci fonctionne mais pas comme je l'ai prévu , il m'affiche juste le résultat sans indication il me faut plus de détail, n'auriez vous pas un tuto à me passer svp???

  8. #8
    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
    Citation Envoyé par Hind4Dev Voir le message
    merci ceci fonctionne mais pas comme je l'ai prévu , il m'affiche juste le résultat sans indication il me faut plus de détail, n'auriez vous pas un tuto à me passer svp???
    Il faut adapter ta requête SQL évidemment, pour récupérer les informations qui t'intéressent. Pour les tutoriels SQL, je suppose qu'en allant dans le forum SGBD/SQL, rubrique Tutoriels, on doit pouvoir en trouver.
    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.

  9. #9
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    j'ai besoin d'afficher la filière,nombre des garçons et nombre des filles ;
    j'ai fait cette instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    String query = "SELECT filiere, genre, COUNT(*) FROM etudiant INNER JOIN filiere ON etudiant.code_f=filiere.code_f  WHERE genre='M' GROUP BY code_f";
    ça me génère cette erreur : Column 'code_f' in group statement is ambiguous


    est-il possible d'avoir le nombre des filles et des garçons dans la même instruction sql pour que je les affiche dans le même tableau?

  10. #10
    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
    Citation Envoyé par Hind4Dev Voir le message
    ça me génère cette erreur : Column 'code_f' in group statement is ambiguous

    Tu as ce message parce que tu as deux champs code_f, et que SQL ne sait pas lequel prendre : etudiant.code_f=filiere.code_f. Il suffit que tu précises lequel (ils sont égaux par la jointure, donc tu peux indiquer n'importe lequel des deux).
    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.

  11. #11
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    même comme ça il génère la même erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INNER JOIN filiere ON code_f

  12. #12
    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
    Citation Envoyé par Hind4Dev Voir le message
    ça me génère cette erreur : Column 'code_f' in group statement is ambiguous
    ?
    C'est dans le group by (on te l'indique dans le message !) qu'il y ambiguïté.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query = "SELECT filiere, genre, COUNT(*) FROM etudiant INNER JOIN filiere ON etudiant.code_f=filiere.code_f  WHERE genre='M' GROUP BY etudiant.code_f";
    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.

  13. #13
    Membre habitué Avatar de Hind4Dev
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Novembre 2014
    Messages
    428
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Novembre 2014
    Messages : 428
    Points : 140
    Points
    140
    Par défaut
    maintenant il m'affiche le genre et la filiere avec le nombre mais comme ça:
    Nom : 2015-11-30_18-01-43.jpg
Affichages : 421
Taille : 21,4 Ko

    ce dont j'ai besoin est d'avoir si possible en java les filières à gauche et en haut les colonnes filles garçons??? comme ceci
    Nom : 2015-11-30_18-07-02.jpg
Affichages : 443
Taille : 20,1 Ko

  14. #14
    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
    C'est plutôt une question de pur SQL à poser dans le forum SQL. En Java, on pourrait traiter le résultat de la requête à plat, pour faire un regroupement (avec des Map, et éventuellement un Collectors.groupingBy()).
    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.

Discussions similaires

  1. Réponses: 4
    Dernier message: 04/02/2008, 11h14
  2. Ranger un tableau de String dans ma HashMap
    Par jeyce dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 26/08/2004, 22h41
  3. Selection listener dans JTable
    Par calypso dans le forum Composants
    Réponses: 3
    Dernier message: 02/08/2004, 17h56
  4. Tableau de vertex dans OpenGL
    Par Guizmo57 dans le forum OpenGL
    Réponses: 5
    Dernier message: 11/04/2004, 09h15
  5. [Kylix] stockage d'un tableau d'octets dans interbase
    Par georges1001 dans le forum EDI
    Réponses: 1
    Dernier message: 16/09/2003, 14h14

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