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

 Java Discussion :

Supprimer les deux lignes en doublons dans un Jtable


Sujet :

Java

  1. #1
    Membre du Club
    Homme Profil pro
    Economiste
    Inscrit en
    Décembre 2016
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Bénin

    Informations professionnelles :
    Activité : Economiste
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Décembre 2016
    Messages : 114
    Points : 63
    Points
    63
    Par défaut Supprimer les deux lignes en doublons dans un Jtable
    Bonjour,
    dans mon projet de gestion de la caisse, je souhaite enregistré des données dans une table de ma Base A (MySQL) provenant d'une autre table d'une autre Base B sans introduire dans la table A ceux qui sont déjà enregistrés. Par le faire, je souhaite chargé les données d'une période donnée de la table B et ceux de la table A dans un même Jtable. J'ai crée un méthode me permettant de vérifier s'il y a de doublons dans le Jtable. Si oui, supprimer les deux lignes qui se répètent avance d'enregistrer le reste. Si non, enregistré directement les données présentent dans le Jtable.
    Actuellement j'ai puis chargé les données des deux tables dans le même Jtable, j'arrive à supprimer les derniers (deuxièmes) doublons mais je n'arrive pas à supprimer les premiers doublons.
    Voici mes codes :
    1- Pour chargé les données dans le Jtable
    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
    	public void consulterRetrait(){
    		SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy");
    		MetierImplTontinier metier=new MetierImplTontinier();
    		Date dateDebut=dateD.getDate();
    		java.sql.Date SqldateD=new java.sql.Date(dateDebut.getTime());
    		Date dateFin=dateF.getDate();
    		java.sql.Date SqldateF=new java.sql.Date(dateFin.getTime());
    		String numAgent=txtnumAgent.getText();
    		String type=cmbType.getSelectedItem().toString();
    		// Chargement de la liste de données provenant de la table A
    		List<PassageTontinierCaisse> mouvement1=metier.consulterRetraitEnregistreCaisse(SqldateD, SqldateF, numAgent,type);
    		// Chargement de la liste de données provenant de la Table B
    		List<Mouvement> mouvement=metier.consulterRetrait(SqldateD, SqldateF, numAgent,type);
    		model=new DefaultTableModel();
    		model.setColumnIdentifiers(new Object[]{"N°","Date", "Compte", "Nom et prénom client","Montant","Agent","Ref"});
    		Object[] rows=new Object[7];
    		int a=1;
    		//Ajout dans le Jtable des données de la table A
       	    for(Mouvement mvt:mouvement){
       	    	rows[0]=a++;
       	    	rows[1]=sdf.format(mvt.getDateMouvement());
       	    	rows[2]=mvt.getNumCompte();
       	    	rows[3]=mvt.getCompte().getClient().getNom()+' '+mvt.getCompte().getClient().getPrenom() ;
     
       	    	rows[4]=mvt.getNombre()*mvt.getCompte().getMontantMise();
       	    	rows[5]=mvt.getNumAgent();
       	    	rows[6]=mvt.getNumero();
       	    	model.addRow(rows);
     
       	    }
       	//Ajout dans le Jtable des données de la table B
       	 for(PassageTontinierCaisse mvt1:mouvement1){
       	    	rows[0]=a++;
       	    	rows[1]=mvt1.getDate();
       	    	rows[2]=mvt1.getNumCompte();
       	    	rows[3]=mvt1.getNomPrenomClient();
     
       	    	rows[4]=mvt1.getMontant();
       	    	rows[5]=mvt1.getNumAgent();
       	    	rows[6]=mvt1.getReferenceTontinier();
       	    	model.addRow(rows);
       	    }
       	    table.setModel(model);
    	   	table.getColumnModel().getColumn(0).setPreferredWidth(15);
    		table.getColumnModel().getColumn(1).setPreferredWidth(65);
    		table.getColumnModel().getColumn(3).setPreferredWidth(150);
    		table.getColumnModel().getColumn(4).setPreferredWidth(65);
    		table.getColumnModel().getColumn(5).setPreferredWidth(15);
     
    	}
    2- Pour la vérification et suppression des doublons
    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 void suprimerLingnesDoublon(){
    		ArrayList<String> list = new ArrayList(); 
    		int rows = table.getRowCount(); 
    		for (int i=rows-1; i>=0; --i){ 
     
    		String data = table.getValueAt(i, 6).toString(); 
    		if (list.contains(data)) { 
     
    			model.removeRow(table.getRowCount()-1);
     
    		} 
    		else{ 
     
    		list.add(data); 
    		} 
    	}
    	}
    Quelqu’un a-t-il une idée de comment faire cela?

  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,

    Tu te compliques bien la vie à charger les deux sources dans une JTable pour dédoublonner puis sauvegarder depuis cette JTable.

    Tu récupères les données de la JTable dans une liste. Tu la parcours et pour chaque ligne, si ça existe déjà, tu la supprimes (avec un parcourt avec Iterator et Iterator.remove(), ou avec un Stream et filter. Et voilà, tu as une liste avec les données qui n'existent pas déjà dans ta base, qui ne te reste plus qu'à sauvegarder ces lignes. Ou tu fais ça directement dans le processus de sauvegarde : tu y parcours déjà des lignes n'est-ce pas ?

    A part ça, il y a une erreur de logique dans ta méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (list.contains(data)) { 
     
    			model.removeRow(table.getRowCount()-1);
     
    		}
    Ce n'est pas la dernière ligne qu'il faut supprimer, mais la ligne courante (i), celle que tu identifies comme existant déjà. Et ce serait mieux d'utiliser un Set plutôt qu'une List pour faire ce genre de chose.
    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 du Club
    Homme Profil pro
    Economiste
    Inscrit en
    Décembre 2016
    Messages
    114
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Bénin

    Informations professionnelles :
    Activité : Economiste
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Décembre 2016
    Messages : 114
    Points : 63
    Points
    63
    Par défaut
    Vraiment merci Joel.drigo rien qu'a lire seulement vos commentaire l'on se retrouve mieux dans son code pour nous les débutants.
    J'ai trouvé la solution dans votre dernière paragraphe. Avec ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (list.contains(data)) { 
    			model.removeRow(i);
    			model.removeRow(table.getRowCount()-1);
     
    		}
    ça marche parfaitement.
    Pour le début de votre commentaire je n'est pas vraiment compris comment je vais écrire le code. Mais je pense que cela sera plus optimale que ce que j'ai fait.
    Une fois encore merci pour votre aide.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/11/2014, 17h03
  2. Supprimer les deux premières lignes du dernier fichier texte créé
    Par Speedoumitic dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 23/07/2013, 16h22
  3. [XL-2003] Supprimer lignes si doublons dans 2 colonnes
    Par amazigh42 dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 12/07/2013, 16h34
  4. Réponses: 2
    Dernier message: 18/09/2011, 06h49
  5. Réponses: 15
    Dernier message: 28/02/2007, 10h00

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