Probleme mit speichern (GUI)

tomiu

Mitglied
Hallo,

warum wenn ich auf speichern1a(Button) klicke, ein Eintrag wird mehrmals gespeichert und nicht nur einmal????

danke im voraus

lg
tomiu

Code:
	 ActionListener sp1A=new ActionListener(){
	        public void actionPerformed(ActionEvent e){

	            Lieferant e1=new Lieferant();

	  try{

	    if ((na_me2.getText().trim().length()>0)&&(vorna_me2.getText().trim().length()>0))
	    {
	    	
	    	
	        e1.setName(na_me2.getText().trim());
	         
	        e1.setVorname(vorna_me2.getText().trim());
	         
	        e1.setAdresse(adr_esen2.getText().trim());
	       
	        e1.setTelNr(tel_nr2.getText().trim());

	        LiefManager.sp1(e1);
	    }
	    else
	        JOptionPane.showMessageDialog(null,"Name und Vorname darf nicht leer sein");


	               
	            
	   }catch(Exception r){

	                JOptionPane.showMessageDialog(null,"Falsche Eingabe");
	            }
	            


	          }
	      };

	      sp_eichern1a.addActionListener(sp1A);//speichern1a ist Button

Code:
public static void sp1(Lieferant e1){

    Connection con=DB.DB2();

    

    //PreparedStatement pstmt = null;


    try{
  
    	String s="INSERT INTO Lieferant(Name,Vorname,Adresse,Telnr)" +
    			"VALUES(?,?,?,?)";
    	 PreparedStatement pstmt = con.prepareStatement(s);
     
        

         pstmt.setString(1,e1.getName());

         pstmt.setString(2,e1.getVorname());

         pstmt.setString(3,e1.getAdresse());

         pstmt.setString(4,e1.getTelNr());

         pstmt.executeUpdate();

               
         JOptionPane.showMessageDialog(null,"Erfolgreich gespeichert");
    	
        }
        catch(SQLException sqle){
            System.err.println(sqle);

        }
        catch(NullPointerException npe){
            System.err.println(npe);
        }
      }
 
G

gman

Gast
Hi,

kannst dir ja mal ausgeben lassen wie viele Einträge gespeichert wurden:

Java:
         int inserts = pstmt.executeUpdate();

               
         JOptionPane.showMessageDialog(null, inserts + " Einträge erfolgreich gespeichert");
 

tomiu

Mitglied
Hi,

kannst dir ja mal ausgeben lassen wie viele Einträge gespeichert wurden:

Java:
         int inserts = pstmt.executeUpdate();

               
         JOptionPane.showMessageDialog(null, inserts + " Einträge erfolgreich gespeichert");

selbes Fenster taucht 3 mal auf..

Rufst du sp1 nur im ActionListener auf? Warum hast du eingentlich so komische Namen? Code conventions

Ja, nur im ActionListener...das mit Code conventions, hast recht...werde später korrigieren
 
Zuletzt bearbeitet:

Runtime

Top Contributor
Mir kommen nur folgende Möglichkeiten in den Sinn:
1. Du registriest den ActionListener 3mal
2. Die Methode sp1 wird ausserhalb des ActionListeners aufgerufen.
 
S

SlaterB

Gast
wahrscheinlich wurden mehrere gleiche/selber ActionListener registriert,
übernimm mal den Anfang meines ActionListeners hier bzw. durch die drei OptionPanes ist ja klar dass 3x der Listener drankommt

fraglich ist dann der weitere Programmaufbau, aus dem ersten Post ist nicht zu erkennen, ob sp1A mehrmals geadded wird,
vielleicht die gesamte Methode mit diesem Code mehrfach aufgerufen..

Java:
public class TestGUI   extends JFrame {
    public TestGUI() {
        JButton b = new JButton("Start");
        ActionListener l = new ActionListener()  {
                public void actionPerformed(ActionEvent e)   {
                    JButton source = (JButton)e.getSource();
                    System.out.println("actionPerformed-Aufruf, source hat Listener: " 
                        + source.getActionListeners().length);
                }
            };
        b.addActionListener(l);
        b.addActionListener(l);
        add(b);

        setSize(200, 200);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setVisible(true);
    }

    public static void main(String[] args)  {
        new TestGUI();
    }
}
 

tomiu

Mitglied
wahrscheinlich wurden mehrere gleiche/selber ActionListener registriert,
übernimm mal den Anfang meines ActionListeners hier bzw. durch die drei OptionPanes ist ja klar dass 3x der Listener drankommt

Stimmt...source hat 3 Listener... habe bemerkt dass der Listener 3mal drankommt nur wenn ich auf zurück klicke (Lief zurück)und dann wieder speichern will

Code:
actionPerformed-Aufruf, source hat Listener: 3

hier die codes(ohne Code conventions..sorry :( )

Code:
package gui;
import java.awt.*;
import java.awt.event.*;
import java.util.Vector;

import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.table.DefaultTableModel;

import lieferant.LiefManager;
import lieferant.Lieferant;

public class Gui extends JFrame{

	public Gui(){
		
		Gui1i();
	}
	
	JLabel l_Id1 =new JLabel("LId:");

	   JTextField l_Id2=new JTextField(2);

	   JLabel na_me1 =new JLabel("Name:");

	    JTextField na_me2=new JTextField(15);

	    JLabel vorna_me1 =new JLabel("Vorname:");

	    JTextField vorna_me2=new JTextField(15);

	    JLabel adr_esen1 =new JLabel("Adresse:");

	    JTextField adr_esen2=new JTextField(20);

	    JLabel tel_nr1 =new JLabel("Telnr:");

	    JTextField tel_nr2=new JTextField(20);

	    JButton zu_rueck1=new JButton("Lief zurueck");
	    JButton sp_eichern1=new JButton("Speichern");
	    JButton sp_eichern1a=new JButton("Speichern");

	   public Object colnames[] ={"Name" ,"Vorname", "Adresse","Telnr" };

	    public Object[][] 	data = {
										{"", "", "", ""}

									};

	    private JTable table=new JTable(data,colnames);

	    private JScrollPane s_table=new JScrollPane(table);


	    private String aus1[]={"Lieferant","Schmuck"};

	    JComboBox a_us1=new JComboBox(aus1);
	    
	    public void Gui1i(){

	        Border leer= BorderFactory.createEmptyBorder();


	        setTitle("Lieferant");

	        setLocation(300,300);

	        setLayout(new GridBagLayout());

	        GridBagConstraints c=new GridBagConstraints();

	 
	        c.gridx = 3;

	        c.gridy = 1;

	        c.anchor = GridBagConstraints.CENTER;

	         
	        getContentPane().add(sp_eichern1,c);




	        c.gridx = 1;

	        c.gridy = 6;

	        c.gridwidth = 5 ;

	        getContentPane().add(s_table,c);

	        
	      ActionListener speichern_lieferant=new ActionListener(){
	        public void actionPerformed(ActionEvent e){

	            getContentPane().removeAll();

	            speich1();

	          }
	      };

	      sp_eichern1.addActionListener(speichern_lieferant);

	     

            pack();

	            setVisible(true);

	            setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

	}
	    
	    
	    



	    public void speich1(){

	        setTitle("Lieferanten speichern");

	        
	        setLocation(300,300);

	        setLayout(new GridBagLayout());

	        GridBagConstraints c=new GridBagConstraints();

	       
	      
	        c.gridx = 1;

	        c.gridy = 2;

	        getContentPane().add(na_me1,c);

	        c.gridx = 2;

	        c.gridy = 2;

	        getContentPane().add(na_me2,c);

	        c.gridx = 1;

	        c.gridy = 3;

	        getContentPane().add(vorna_me1,c);

	        c.gridx = 2;

	        c.gridy = 3;

	        getContentPane().add(vorna_me2,c);

	        c.gridx = 1;

	        c.gridy = 4;

	        getContentPane().add(adr_esen1,c);

	        c.gridx = 2;

	        c.gridy = 4;

	        getContentPane().add(adr_esen2,c);

	        c.gridx = 1;

	        c.gridy = 5;

	        getContentPane().add(tel_nr1,c);

	        c.gridx = 2;

	        c.gridy = 5;

	        getContentPane().add(tel_nr2,c);

	        c.gridx = 3;

	        c.gridy = 3;

	        c.anchor = GridBagConstraints.CENTER;

	        getContentPane().add(sp_eichern1a,c);

	        c.gridx = 7;

	        c.gridy = 3;

	        c.anchor = GridBagConstraints.CENTER;

	        getContentPane().add(zu_rueck1,c);


	        c.gridx = 1;

	        c.gridy = 6;

	        c.gridwidth = 5 ;

	        getContentPane().add(s_table,c);

	       
	 ActionListener sp1Action=new ActionListener(){
	        public void actionPerformed(ActionEvent e){

	            Lieferant e1=new Lieferant();
	            JButton source = (JButton)e.getSource();
                System.out.println("actionPerformed-Aufruf, source hat Listener: " 
                    + source.getActionListeners().length);

	  try{

	    if ((na_me2.getText().trim().length()>0)&&(vorna_me2.getText().trim().length()>0))
	    {
	    	
	    	
	        e1.setName(na_me2.getText().trim());
	         
	        e1.setVorname(vorna_me2.getText().trim());
	         
	        e1.setAdresse(adr_esen2.getText().trim());
	       
	        e1.setTelNr(tel_nr2.getText().trim());

	        LiefManager.sp1(e1);
	    }
	    else
	        JOptionPane.showMessageDialog(null,"Name und Vorname darf nicht leer sein");


	               
	            
	   }catch(Exception r){

	                JOptionPane.showMessageDialog(null,"Falsche Eingabe");
	            }
	            


	          }
	      };

	      sp_eichern1a.addActionListener(sp1Action);

	       
          ActionListener zu1=new ActionListener(){
 	          public void actionPerformed(ActionEvent e){

 	              getContentPane().removeAll();
 	              Gui1i();
 	          }
 	        };

 	        zu_rueck1.addActionListener(zu1);

	       pack();

	       setVisible(true);

	       setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

	  }


}


hier ist sie sp1 methode:

Code:
package lieferant;

import java.sql.*;

import db.DB;
import java.util.*;

import javax.swing.*;



public class LiefManager {

	     //Speichern
    public static void sp1(Lieferant el1){

    Connection con=DB.DB2();

    

    //PreparedStatement pstmt = null;


    try{
  
    	String s="INSERT INTO Lieferant(Name,Vorname,Adresse,Telnr)" +
    			"VALUES(?,?,?,?)";
    	 PreparedStatement pstmt = con.prepareStatement(s);
     
        

         pstmt.setString(1,el1.getName());

         pstmt.setString(2,el1.getVorname());

         pstmt.setString(3,el1.getAdresse());

         pstmt.setString(4,el1.getTelNr());

         int inserts = pstmt.executeUpdate();

         JOptionPane.showMessageDialog(null, inserts + " Einträge erfolgreich gespeichert");
        
         
        // JOptionPane.showMessageDialog(null,"Erfolgreich gespeichert");
    	
        }
        catch(SQLException sqle){
            System.err.println(sqle);

        }
        catch(NullPointerException npe){
            System.err.println(npe);
        }
      }

}
 
Zuletzt bearbeitet:
S

SlaterB

Gast
besteht eine Frage?
das Problem dürfte offensichtlich (edit: unter anderem) sein, dass bei Zurück
> Gui1i();
aufgerufen wird, Einfügen in die GUI mit Layout usw. ist korrekt nach dem removeAll(), aber es wird auch der Listener neu geadded
(sehe an deinem edit dass du das nun auch erkannt hast, deshalb nochmal: besteht eine Frage oder ist alles geklärt?)

-----

zu deiner Code-Qualität:
Code-Conventions ist eine Sache, aber fällt dir nicht selber auf wie unendlich unleserlich das ganze ist mit Leerzeilen nach JEDER Zeile?
selbst wenn du das nicht aktiv so hast sondern das irgendein Kopier-Programm einfügt, kannst du den Text doch immer noch kurz in einen Editor setzen und (gewiss 5 Min. lang) die Leerzeilen entfernen

und [ java ] statt [ code ] hilft auch ungemein
 
Zuletzt bearbeitet von einem Moderator:

Michael...

Top Contributor
Wo lernt man so zu programmieren... und blickst Du in Deinem Code überhaupt noch selbst durch?

Zu Deinem Problem:
Jedesmal wenn Du auf den Button sp_eichern1 drückst erzeugst Du einen neuen ActionListener (der letztendlich die Methode zum Speichern in der DB aufruft) und registrierst an sp_eichern1a.
 

tomiu

Mitglied
besteht eine Frage?
das Problem dürfte offensichtlich (edit: unter anderem) sein, dass bei Zurück
> Gui1i();
aufgerufen wird, Einfügen in die GUI mit Layout usw. ist korrekt nach dem removeAll(), aber es wird auch der Listener neu geadded
(sehe an deinem edit dass du das nun auch erkannt hast, deshalb nochmal: besteht eine Frage oder ist alles geklärt?)

-----

zu deiner Code-Qualität:
Code-Conventions ist eine Sache, aber fällt dir nicht selber auf wie unendlich unleserlich das ganze ist mit Leerzeilen nach JEDER Zeile?
selbst wenn du das nicht aktiv so hast sondern das irgendein Kopier-Programm einfügt, kannst du den Text doch immer noch kurz in einen Editor setzen und (gewiss 5 Min. lang) die Leerzeilen entfernen

und [ java ] statt [ code ] hilft auch ungemein

ich bin körperlich behindert un deswegen kann nicht immer die Code-Conventions verwenden..es kostet mir sehr viel Zeit(ich schreibe mit Fuß nicht mit Hände)..arbeite mit spezielle Software und mache nur copy/paste wenn es um namen von Objekten oder Variablen geht...

meine Frage: wie kann ich machen dass der Listener nicht geadded wird??

danke im voraus
 
S

SlaterB

Gast
da du alle Objekte schon ganz zu Anfang erstellst kannst du auch die Listener zu Beginn, im Konstruktor zuweisen,
verschiebe den Code für die drei Listener und die addActionListener()-Aufrufe alle in den Konstruktor,

vor oder hinter dem
Gui1i();
Aufruf dort
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Probleme bei Speicherung eines Integer-Array in Datei speichern Java Basics - Anfänger-Themen 3
M Klassen Probleme beim Debuggen - Datentypkonvertierung - Speichern in Datei Java Basics - Anfänger-Themen 7
J Probleme mit drucken aus Java Java Basics - Anfänger-Themen 3
R Exceptions mit try-catch-Surrounding - Probleme Java Basics - Anfänger-Themen 6
D Probleme bei Verwendung short und int im Constuctor Java Basics - Anfänger-Themen 6
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12
F Probleme mit privaten Klassen (abstrakten Klassen) Java Basics - Anfänger-Themen 1
H Probleme mit Klassen...oder: Eine Uhr Java Basics - Anfänger-Themen 9
G Probleme mit Konsole Java Basics - Anfänger-Themen 4
S Probleme mit GamGrid Spiel-Erstellung => Actor reagiert nicht auf Tastatur Java Basics - Anfänger-Themen 2
G Probleme mit Eclipse oder der URL Klasse Java Basics - Anfänger-Themen 5
W Verständnis Probleme bei der while-Schleife und continue Java Basics - Anfänger-Themen 21
M Probleme mit Anzeigen von String in GUI und if-Anweisung Java Basics - Anfänger-Themen 9
T Konstruktor Probleme Java Basics - Anfänger-Themen 3
W Methoden Probleme mit der Scanner Methode Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben