set Integer bzw. set null mit SQL DB

maGG

Bekanntes Mitglied
Hallo ihr Lieben, folgender Code:
Java:
  private void jButtonSaveA2ActionPerformed(java.awt.event.ActionEvent evt) {                                             
        try{
            String sql = "INSERT INTO Filialen_Ausland (id,LABEL,STRASZE,PLZ_ORT,ORT,TEL_LAND,TEL_ANFANG_INT,"
            + "TEL_ANFANG_TXT,TEL_ENDE_DEFAULT,FAX_ANFANG_TXT,FAX_ENDE_TXT) "
            + "VALUES(?,?,?,?,?,?,?,?,?,?,?)";
            pst = conn.prepareStatement(sql);
            pst.setInt(1,Integer.parseInt(jTextFieldA1.getText()));
            pst.setString(2,jTextFieldA2.getText());
            pst.setString(3,jTextFieldA3.getText());
            pst.setString(4,jTextFieldA4.getText());
            pst.setString(5,jTextFieldA5.getText());
            pst.setInt(6,Integer.parseInt(jTextFieldA6.getText()));
            pst.setInt(7,Integer.parseInt(jTextFieldA7.getText()));
            pst.setString(8,jTextFieldA8.getText());
            pst.setInt(9,Integer.parseInt(jTextFieldA9.getText()));
            pst.setString(10,jTextFieldA10.getText());
            pst.setString(11,jTextFieldA11.getText());
            pst.execute();
            Update_Table_Filialen_Ausland();
            JOptionPane.showMessageDialog(null, "Filiale hinzugefügt");
            try{
                //rs.close();
                pst.close();
                conn.close();
            }catch(SQLException e){
                e.printStackTrace();
                JOptionPane.showMessageDialog(null, e);
            }
        }catch(Exception e){
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e);
        }
    }
Problem: wenn eines der Textfelder leer ist funktioniert das Ganze mit setInt nicht, weil setInt zwei int-Werte setzt und int nicht null werden kann oder?
Ich bräuchte also den Datentyp Integer...

wie könnte ich dieses Problem lösen? Habt ihr ein Tipp für mich, was ich machen könnte?

Vielen Dank!
 

JVolker

Aktives Mitglied
Hi,

Kann man das Feld nicht mit einer "0" initialisieren? Bin jetzt leider auch nur blutiger Anfänger. Kann man den Wert den du einliest evtl. mi 0 addieren?
 

Robat

Top Contributor
Also entweder fügst du eine ordentliche Eingabeüberprüfung durch und lässt gar nicht erst zu, dass das Feld leer bleibt oder du musst eben den Wert per default auf 0 (oder was auch immer) setzen.
 

maGG

Bekanntes Mitglied
Hmm leider kann ich den Wert für TEL_ENDE_DEFAULT nicht 0 werden lassen. Denn in meinen verarbeitenden Methoden würde die Telefonnummer dann eine 0 angehängt bekommen, wo dann gar keine hin soll.

Ich hab also Standorte, bei denen die Telefonnummer eine Zusatznummer am Ende hat, z.B. 012345678-9 oder eben ohne: 012345678, in diesem Fall ist die Spalte TEL_ENDE_DEFAULT null. Also muss ich irgendeine andere Lösung finden, mir fällt jedoch gerade keine ein.

Habt ihr Ideen?
 

maGG

Bekanntes Mitglied
habs jetzt so gelöst ...
Java:
        if(jTextFieldA1.getText().equals("") || jTextFieldA2.getText().equals("") || jTextFieldA3.getText().equals("") ||
                jTextFieldA4.getText().equals("") || jTextFieldA5.getText().equals("") || jTextFieldA6.getText().equals("") ||
                jTextFieldA7.getText().equals("") || jTextFieldA8.getText().equals("") || jTextFieldA10.getText().equals("")){
            JOptionPane.showMessageDialog(null, "Fehler: Bitte notwendige Parameter setzen");
        }else{     
        try{
            String sql = "INSERT INTO Filialen_Ausland (id,LABEL,STRASZE,PLZ_ORT,ORT,TEL_LAND,TEL_ANFANG_INT,"
            + "TEL_ANFANG_TXT,TEL_ENDE_DEFAULT,FAX_ANFANG_TXT,FAX_ENDE_TXT) "
            + "VALUES(?,?,?,?,?,?,?,?,?,?,?)";
            pst = conn.prepareStatement(sql);
            pst.setInt(1,Integer.parseInt(jTextFieldA1.getText()));
            pst.setString(2,jTextFieldA2.getText());
            pst.setString(3,jTextFieldA3.getText());
            pst.setString(4,jTextFieldA4.getText());
            pst.setString(5,jTextFieldA5.getText());
            pst.setInt(6,Integer.parseInt(jTextFieldA6.getText()));
            pst.setInt(7,Integer.parseInt(jTextFieldA7.getText()));
            pst.setString(8,jTextFieldA8.getText());
            if(jTextFieldA9.getText().equals("")){    
                pst.setObject(9, null);
            }else{
                pst.setInt(9,Integer.parseInt(jTextFieldA9.getText()));
            }
            pst.setString(10,jTextFieldA10.getText());
            if(jTextFieldA11.getText().equals("")){
                pst.setObject(11, null);
            }else{
                pst.setString(11,jTextFieldA11.getText());
            }
            pst.execute();
            Update_Table_Filialen_Ausland();
            JOptionPane.showMessageDialog(null, "Filiale hinzugefügt");
            try{
                //rs.close();
                pst.close();
                //conn.close();
            }catch(SQLException e){
                e.printStackTrace();
                JOptionPane.showMessageDialog(null, e);
            }
        }catch(Exception e){
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e);
        }
        }
    }

Allerdings hab ich bei der Update Funktion jetzt auch ein Problem:

Java:
    private void jButtonUpdateA2ActionPerformed(java.awt.event.ActionEvent evt) {                                               
        try{
            Integer value1 = Integer.parseInt(jTextFieldA1.getText());
            String value2 = jTextFieldA2.getText();
            String value3 = jTextFieldA3.getText();
            String value4 = jTextFieldA4.getText();
            String value5 = jTextFieldA5.getText();
            Integer value6 = Integer.parseInt(jTextFieldA6.getText());
            Integer value7 = Integer.parseInt(jTextFieldA7.getText());
            String value8 = jTextFieldA8.getText();
            Integer value9;
            if(jTextFieldA9.getText().equals("")){    
                value9 = null; //hier läuft etwas schief
            }else{
                value9 = Integer.parseInt(jTextFieldA9.getText());
            }
            String value10 = jTextFieldA10.getText();
            String value11;
            if(jTextFieldA11.getText().equals("")){    
                value11 = "";
            }else{
                value11 = jTextFieldA11.getText();
            }
           
            String sql = "UPDATE Filialen_Ausland SET id='" + value1 + "', LABEL='" + value2 +
            "', STRASZE='" + value3 + "', PLZ_ORT='" + value4 + "', ORT='" + value5 +
            "', TEL_LAND='" + value6 + "', TEL_ANFANG_INT='" + value7 + "', TEL_ANFANG_TXT='" + value8 +
            "', TEL_ENDE_DEFAULT='" + value9 + "', FAX_ANFANG_TXT='" + value10 + "', FAX_ENDE_TXT='" + value11 +
            "' WHERE id='" + value1+"' ";
            pst = conn.prepareStatement(sql);
            pst.execute();
            Update_Table_Filialen_Ausland(); //aktualisiert jTable nach Editieren
            JOptionPane.showMessageDialog(null, "Datenbank aktualisiert");
            try{
                pst.close();
            }catch(Exception e){
                e.printStackTrace();
                JOptionPane.showMessageDialog(null, e);
            }
        }catch(Exception e){
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e);
        }
    }

Klappt alles bisher perfekt, allerdings für value9 bzw. TEL_ENDE_DEFAULT wird null in der jTable als String ausgeschrieben, anstelle das die Zelle leer bleibt pfffffff stehe auf dem Schlauch...

Ideen? :)
 

maGG

Bekanntes Mitglied
Java:
    private void jButtonUpdateA2ActionPerformed(java.awt.event.ActionEvent evt) {                                               
        try{          
            String sql = "UPDATE Filialen_Ausland SET id=?, LABEL=?, STRASZE=?, PLZ_ORT=?, ORT,TEL_LAND=?, TEL_ANFANG_INT=?,"
            + " TEL_ANFANG_TXT=?, TEL_ENDE_DEFAULT=?, FAX_ANFANG_TXT=?, FAX_ENDE_TXT=? WHERE id=?";
           
            pst = conn.prepareStatement(sql);
            pst.setInt(1,Integer.parseInt(jTextFieldA1.getText()));
            pst.setString(2,jTextFieldA2.getText());
            pst.setString(3,jTextFieldA3.getText());
            pst.setString(4,jTextFieldA4.getText());
            pst.setString(5,jTextFieldA5.getText());
            pst.setInt(6,Integer.parseInt(jTextFieldA6.getText()));
            pst.setInt(7,Integer.parseInt(jTextFieldA7.getText()));
            pst.setString(8,jTextFieldA8.getText());
            if(jTextFieldA9.getText().equals("")){    
                pst.setObject(9, null);
            }else{
                pst.setInt(9,Integer.parseInt(jTextFieldA9.getText()));
            }
            pst.setString(10,jTextFieldA10.getText());
            if(jTextFieldA11.getText().equals("")){
                pst.setObject(11, null);
            }else{
                pst.setString(11,jTextFieldA11.getText());
            }
            pst.setInt(12,Integer.parseInt(jTextFieldA1.getText()));
            pst.executeUpdate();
            Update_Table_Filialen_Ausland();
            JOptionPane.showMessageDialog(null, "Filiale aktualisiert");
        }catch(Exception e){
            e.printStackTrace();
            JOptionPane.showMessageDialog(null, e);
        }finally{
            try{
                if (pst != null) {
                    pst.close();
                }
            }catch(Exception e){
                e.printStackTrace();
                JOptionPane.showMessageDialog(null, e);
            }
            }
    }
An meinem SQL Code müsste irgendetwas falsch sein (er gibt mir nen Syntax Error aus), weiß aber nicht was ich falsch gemacht hab :(
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
O Datentypen Integer mit führender Null Java Basics - Anfänger-Themen 13
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
MoxMorris Integer.MAX_VALUE und Double.MAX_VALUE Unterschied Java Basics - Anfänger-Themen 3
Jul1n4tor Scanner error bei Eingabe die kein Integer ist Java Basics - Anfänger-Themen 4
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
sserio printf integer formatting Java Basics - Anfänger-Themen 17
M Unterschied Integer.toString(x) und x.toString() Java Basics - Anfänger-Themen 22
H Uhrzeitespanne in Integer Wert umrechnen Java Basics - Anfänger-Themen 1
T Java Integer multiplizieren Java Basics - Anfänger-Themen 6
H Fehler bei integer Division Java Basics - Anfänger-Themen 28
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
StevenGG Java swing "New Integer" Java Basics - Anfänger-Themen 5
C Integer in Vierer-Zahlblöcke aufteilen Java Basics - Anfänger-Themen 11
L integer Java Basics - Anfänger-Themen 6
Zeppi Integer umschreiben Java Basics - Anfänger-Themen 5
rafi072001 Integer Anomalie Java Java Basics - Anfänger-Themen 7
Eule25 Arbeit mit long und int, Error: integer number too large Java Basics - Anfänger-Themen 2
J Transformation zweier Integer in ein Double Java Basics - Anfänger-Themen 26
M Integer aus aus einer Klasse in andere speichern Java Basics - Anfänger-Themen 12
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
D Fibonacci overflow integer Java Basics - Anfänger-Themen 8
J Eine Position im String durch einen Integer - Wert teilen Java Basics - Anfänger-Themen 5
S Integer Wert wird nicht übernommen Java Basics - Anfänger-Themen 2
V int zu Integer und String Java Basics - Anfänger-Themen 6
H Datentypen Was für eine Format verbirgt sich hinter dem Integer-Wert 053? Java Basics - Anfänger-Themen 2
L Baum aus Integer Liste erstellen Java Basics - Anfänger-Themen 0
M Regex zum Integer.parseInt Java Basics - Anfänger-Themen 4
J Problem beim vergleich von zwei Integer Java Basics - Anfänger-Themen 3
S Vergleichen ob der Integer der benutzt eingeben werden soll überhaupt ein int ist Java Basics - Anfänger-Themen 1
S Letzte Zahl eines Integer auslesen? Java Basics - Anfänger-Themen 3
K String in Integer umwandeln Java Basics - Anfänger-Themen 4
G Überprüfen ob alle Ziffern von 1-9 in einem Integer vorhanden sind Java Basics - Anfänger-Themen 6
D integer negativen Wert abspeichern Java Basics - Anfänger-Themen 3
A Mit JComboBox Ergebnis einen Integer aus einer anderen Klasse aufrufen. Java Basics - Anfänger-Themen 2
J Methoden Moving a n integer matrix Java Basics - Anfänger-Themen 3
R Eingabe String umwandeln zu Integer Werten Java Basics - Anfänger-Themen 8
M Input/Output Java Swing: Prüft ob Text aus JTextField ausschließlich Integer enthält Java Basics - Anfänger-Themen 15
J Erhöhen eines Values als Integer bei gleichen Keys in HashMap Java Basics - Anfänger-Themen 12
CptK Datentypen Integer ArrayList sortieren Java Basics - Anfänger-Themen 2
J Methoden Equals Methode für Integer und Objekte überschreiben? Java Basics - Anfänger-Themen 9
CptK Bestimmten Integer Wert aus Array filtern Java Basics - Anfänger-Themen 2
L String in Integer umwandeln Java Basics - Anfänger-Themen 3
K Datentypen String zu Integer parsen Java Basics - Anfänger-Themen 2
B Liste von Integer -> Nächster Wert bekommen Java Basics - Anfänger-Themen 5
S Integer aus Array filtern Java Basics - Anfänger-Themen 4
F Referenzvariable vom Typ "Integer" definieren. (Klausuraufgabe) Java Basics - Anfänger-Themen 5
H Bubblesort-Zwei Integer auf Dekade vergleichen. Java Basics - Anfänger-Themen 6
B Variablen integer im Array Java Basics - Anfänger-Themen 5
C Liste o.ä. erstellen mit <Integer, <Integer, String> Java Basics - Anfänger-Themen 7
R Kompletten String umwandeln in Integer Java Basics - Anfänger-Themen 10
H 32-Bit Zahl (Integer) in eine IPv4 Adresse umwandeln? Java Basics - Anfänger-Themen 2
Orkanson Datentypen Integer in String umwandeln/hinzufügen Java Basics - Anfänger-Themen 3
M Argument in Integer verwandeln und das Doppelte davon printen Java Basics - Anfänger-Themen 9
D Fehler: String zu Integer Java Basics - Anfänger-Themen 7
L (Integer) Liste nach aufsteigender Summe der Ziffern sortieren (mit Bedingung) Java Basics - Anfänger-Themen 8
b1ck Integer initialisieren bei do-while-Schleife Java Basics - Anfänger-Themen 11
E Integer und Array übergeben Java Basics - Anfänger-Themen 9
W Fehler bei Integer.parseInt() Java Basics - Anfänger-Themen 4
R String in Integer Java Basics - Anfänger-Themen 11
D Komischer Fehler nach <Integer> List Java Basics - Anfänger-Themen 2
J Integer in Array einlesen Java Basics - Anfänger-Themen 14
J Warum ist das ein Unterschied (Integer / int) Java Basics - Anfänger-Themen 2
H Integer in Datei schreiben Java Basics - Anfänger-Themen 2
B OOP Cannot instantiate the type AuDList<Integer> Java Basics - Anfänger-Themen 18
3 ArrayList Integer Wrapper Klasse als Ersatz für normale Arrays Java Basics - Anfänger-Themen 10
K Methoden Integer runden/aufrunden Java Basics - Anfänger-Themen 2
E Erste Schritte Lower Bounded Wildcards <? super Integer> Java Basics - Anfänger-Themen 1
M Datentypen Integer und Float Konflikt Java Basics - Anfänger-Themen 3
J Integer-Werte in Array ein- bzw. auslesen Java Basics - Anfänger-Themen 7
T Integer Wert in andere Methode übergeben Java Basics - Anfänger-Themen 2
N Probleme bei Speicherung eines Integer-Array in Datei speichern Java Basics - Anfänger-Themen 3
C Zwei Integer Arrays "kombinieren" Java Basics - Anfänger-Themen 10
D Integer Fehlermeldung exception Java Basics - Anfänger-Themen 4
M Höchster Integer aus 9 Zahlen Java Basics - Anfänger-Themen 13
I Klassen Integer von BL in GUI übergeben | Fehler Java Basics - Anfänger-Themen 4
T Integer-Objekt über Hash-Funktion in Array ablegen Java Basics - Anfänger-Themen 1
S Integer/Value-Paar in Prio-Queue ohne Comparator Java Basics - Anfänger-Themen 5
D Datentypen Ein Integer Feld in einen String wandeln ohne Nullenunterdrückung Java Basics - Anfänger-Themen 6
R integer zahlenfolge speichern, ausgeben Java Basics - Anfänger-Themen 1
L Summer aller Integer-Zahlen im Intervall [x,y] Java Basics - Anfänger-Themen 6
K ArrayList<Integer> problem Java Basics - Anfänger-Themen 3
L Vom Benutzer eingebene Integer addieren und ausgeben. Java Basics - Anfänger-Themen 11
S integer absteigend sortieren Java Basics - Anfänger-Themen 2
S ArrayList<ArrayList<Integer>> sortieren Java Basics - Anfänger-Themen 3
T Variablen Integer in Stmt Java Basics - Anfänger-Themen 13
B gemischter string zu integer Java Basics - Anfänger-Themen 22
R Big Integer Java Basics - Anfänger-Themen 8
B Erste Schritte Integer Eingabe über Scanner mit Abfangen von Eingabefehlern Java Basics - Anfänger-Themen 3
B Variablen Wertezuweisung bei integer Java Basics - Anfänger-Themen 5
J Integer Werte in Array einlesen Java Basics - Anfänger-Themen 6
E Integer oder Strings spiegeln (in while loop) Java Basics - Anfänger-Themen 6
D String mit Integer Variablen Namen vergleichen, möglich? Java Basics - Anfänger-Themen 6
G Was passiert bei einem Overflow von zwei Integer Java Basics - Anfänger-Themen 6
H Integer.toString(int i) vs. String.valueOf(int i) Java Basics - Anfänger-Themen 12
K Date cannot be cast to java.lang.Integer Java Basics - Anfänger-Themen 4
N Probleme beim Rechnen mit Integer und double Java Basics - Anfänger-Themen 4
A Integer aus Stream to Double Java Basics - Anfänger-Themen 7
J Integer.parseInt Java Basics - Anfänger-Themen 23

Ähnliche Java Themen

Neue Themen


Oben