in eine Tabelle mit mySQL eine Zeile hinzufügen

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
Hallo,

ich kann auf eine Tabelle zugreifen.
Auslesen klappt problemlos, indem ich ein Statement erzeuge und dann mit einem ResultSet die Daten auslese.

Wenn ich aber eine Zeile hinzufügen will, wie mache ich das?
Wenn ich das INSERT usw in ein ResultSet schreibe gibt es einen Fehler (ich nehm an weil es ja auch ein ResultSet ist).
Aber wie kann ich dann die Daten in die Tabelle schreiben?
Brauche ich dafür überhaupt ein Statement?
Wie gehe ich genau vor?

Und folgendes:
Code:
INSERT INTO tabelle(Spalte1, Spalte2, Spalte3) VALUES(wert1, wert2, wert3);
wert1 und wert2 sind Variablen, die einen String enthalten, wert3 enthält einen double.
Kann ich Variablen überhaupt hineinschreiben?
(Die Tabelle erwartet schon String, String, double)

Wäre super, wenn ihr mir helfen könntet! :)
 
R

realbora

Gast
Hallo,

Für den insert benötigst du eigentlich kein ResultSet.
Der Code könnte dann in etwa so aussehen:

Code:
connection=DriverManager.getConnection(db_path,"root","");
query=connection.createStatement();
query.executeUpdate("insert into tab_name(spalte1,spalte2,spalte3)values('','"+var_name+"','')");


Vielleicht hilft dir das.
 
G

Guest

Gast
realbora hat gesagt.:
Hallo,

Für den insert benötigst du eigentlich kein ResultSet.
Der Code könnte dann in etwa so aussehen:

Code:
connection=DriverManager.getConnection(db_path,"root","");
query=connection.createStatement();
query.executeUpdate("insert into tab_name(spalte1,spalte2,spalte3)values('','"+var_name+"','')");


Vielleicht hilft dir das.
Vielen Dank für eure Hilfe erstmal!

Mein Problem ist jetzt, dass ich eine Fehlermeldung erhalte, und zwar: Data truncation: Data truncated for column 'spalte3' at row 1.
:bahnhof:

Jedoch stehen in dieser Spalte sicher Strings (hab selbre welche ausgelesen) und ich will auch einen String hinschicken.

Was mach ich noch falsch?
 
G

Guest

Gast
tut mir leid, dass ich den thread nochmal hochzieh.
hat denn keiner einen tip zu diesem problem?
ich häng hier dran gerade und komm nicht weiter. :(
 
R

realbora

Gast
Doch, ich hab einen!

Bei dem Datenbankpfad setze doch einfach mal hinter dem Namen der Datenbank, mit der du dich verbindest das hier "?jdbcCompliantTruncation=false"!

Dann funzt das auch!
 
G

Guest

Gast
Meinst du mit Datenbankpfad diese Zeile, in der ich das INSERT schreibe, oder allgemein, wenn ich die Verbindung aufbau?

Und kannst du vielleicht nochmal schnell erklären, wie ich die Variablen reinschreiben muss, da sind etwas viele ' und " :D
 

realbora

Mitglied
In der Zeile, wo du den Datenbankserver als String einträgst.
Sieht in etwa so aus:
String db_path="jdbc:mysql://localhost/db?jdbcCompliantTruncation=false";
 

realbora

Mitglied
Ich gehe auch mal davon aus, dass du einen mysql-db-server unter Version 4.2 hast!
Dann kannst du auch ne neuere Version installieren und der Fehler müsste weg sein!
 
G

Guest

Gast
Ja, 4.1.19 läuft auf dem Server.
Allerdings ist das nicht meiner und ich darf da nichts ändern.

Gibts noch eine andere Lösungsmöglichkeit?
 

realbora

Mitglied
Wenn das mit dem "?jdbcCompliantTruncation=false" nicht funktioniert weiss ich leider auch nicht weiter.
Hast du das denn schon mal ausprobiert?
 
G

Guest

Gast
Ja hab ich, dann kommt der Fehler zwar nicht mehr, aber an der Tabelle tut sich auch nichts.

Kannst du mir bitte nochmal ein Beispiel geben, wie ich die Variablen im INSERT Statement benutze?

Das würde mir sicher auch etwas weiterhelfen.
 

realbora

Mitglied
executeUpdate("insert into rechnung(id,nummer,kunden_nr)values('','"+reNr+"','1')");


In dieser Tabelle wird der Wert der Variablen "reNr" in die zweite Spalte geschrieben.
Die erste Spalte ist ein Auto_Increment-Wert und in der letzten Spalte wird einfach nur eine "1" in geschrieben.
Vielleicht liegt dein Problem auch in den Datentypen der einzelnen Spalten.
Ein Versuch wäre es wert, wenn du alle Datentypen auch "char" setzt, dann fügt mysql jeden Wert als String ein!
Das könnte zumindest für die Fehlersuche helfen.
 
G

Guest

Gast
Hab grade bemerkt, dass wenn ich für den double-Wert eine Zahl eingebe ( '10'), dann funktioniert das ganze.
Als Variable ('doubleWert') krieg ich allerdings immer noch den Fehler.
 

realbora

Mitglied
Da du die query als String übergibst, ist das klar, dass mysql mit dem String "doubleWert" nichts anfangen kann, weil das ja eigentlich ne zahl sein soll.
Deswegen musst du den Query-String "unterbrechen" und darin die Variable schreiben und das ganze dann wieder mit dem String-Verknüpfungs-Operator + verbinden.
deine Values müssen dann irgendwie so aussehen:
Code:
values('"+doubleWert+"','1','"+hierNeAndereVariable+"','2');

Hier siehts du bestimmt den Unterschied!
Die Werte 1 und 2 sind statische Zahlenwerte, wobei doubleWert und hierNeAndereVariable die Variablen des Programms sind!

Ich hoffe, dass dich das jetzt zum Erfolg führt.[/code]
 

Caffè Latte

Bekanntes Mitglied
Hi,

mit prepared Statements hat man solche Probleme nicht. Deshalb hier nochmals explizit der Hinweis darauf. :)

Code:
        // Prepare a statement to insert a record
        String sql = "INSERT INTO my_table("
            + "col_boolean,"
            + "col_byte,"
            + "col_short,"
            + "col_int,"
            + "col_long,"
            + "col_float,"
            + "col_double,"
            + "col_bigdecimal,"
            + "col_string,"
            + "col_date,"
            + "col_time,"
            + "col_timestamp) "
            + "VALUES(?,?,?,?,?,?,?,?,?,?,?,?)";
        PreparedStatement pstmt = connection.prepareStatement(sql);
    
        // Set the values
        pstmt.setBoolean(1, true);
        pstmt.setByte(2, (byte)123);
        pstmt.setShort(3, (short)123);
        pstmt.setInt(4, 123);
        pstmt.setLong(5, 123L);
        pstmt.setFloat(6, 1.23F);
        pstmt.setDouble(7, 1.23D);
        pstmt.setBigDecimal(8, new BigDecimal(1.23));
        pstmt.setString(9, "a string");
        pstmt.setDate(10, new java.sql.Date(System.currentTimeMillis()));
        pstmt.setTime(11, new Time(System.currentTimeMillis()));
        pstmt.setTimestamp(12, new Timestamp(System.currentTimeMillis()));

Hoffe es hilft ...
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Anpassung der Spaltenbreite auch auf eine zweite Tabelle anwenden Java Basics - Anfänger-Themen 8
S Datenbank Tabelle eine Zeile an einer bestimmten Stelle einfügen Java Basics - Anfänger-Themen 2
B Kann man eine Tabelle in Eclipse erzeugen und damit arbeiten? Java Basics - Anfänger-Themen 8
I Daten aus Arraylists in eine Tabelle übertragen Java Basics - Anfänger-Themen 2
A Im Telefonbuch eine Tabelle ergänzen Java Basics - Anfänger-Themen 6
Beckenbauer OOP Durch Komma getrennte Einträge in einem String in ein Array oder eine Tabelle schreiben Java Basics - Anfänger-Themen 4
Z Array mit daten einer datenbankbefüllen und dies an eine tabelle geben Java Basics - Anfänger-Themen 6
M Einfügen von Daten in eine Tabelle Java Basics - Anfänger-Themen 9
W Eine Zelle einer Tabelle die Schriftfarbe ändern Java Basics - Anfänger-Themen 5
G Null P. E. beim einlesen von daten in eine tabelle? Java Basics - Anfänger-Themen 2
G Daten in eine DB-Tabelle schreiben Java Basics - Anfänger-Themen 3
V Daten aus Access in eine Tabelle schreiben Java Basics - Anfänger-Themen 3
J Objekte einer ArrayList in eine Tabelle einfügen Java Basics - Anfänger-Themen 2
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
K Warum wird hier nur etwas in eine txt Datei geschrieben und nicht in alle drei (InputStream/OutputStream/Reader/Writer) Java Basics - Anfänger-Themen 1
I In unterschiedlichen Applikation Zugriff auf eine gemeinsame Anwendung? Java Basics - Anfänger-Themen 8
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
T Ich brauche eine Schleife die eine beliebige Zahl so lange durch 10 teilt bis zur Null Java Basics - Anfänger-Themen 5
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
N Ich kriege ganze zeit die Fehlermeldung "Inhalt der Zwischenablage kann nicht in die ausgewählten Elemente eingefügt werden" hat jemand eine Lösung? Java Basics - Anfänger-Themen 6
M Vergleichen, ob eine Liste länger als andere ist Java Basics - Anfänger-Themen 6
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
G Wie wartet man bis ein URL eine Antwort zurückgibt? Java Basics - Anfänger-Themen 5
berserkerdq2 Intelij, wie kann ich einstellen, dass die aktuelle Klasse ausgeführt wird, wenn ich aufs Startsymbol drücke, gibts da eine Tastenkombination? Java Basics - Anfänger-Themen 11
S 2 Reihen ratio-btn, eine Reihe funktioniert andere nicht Java Basics - Anfänger-Themen 4
T Eingabe durch eine Zahl dividieren nachgucken? Java Basics - Anfänger-Themen 4
M mit Maven eine ausführbare Jar bauen Java Basics - Anfänger-Themen 7
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
J Zugriff auf eine 2. Klasse die per UI-Designer erstellt wurde Java Basics - Anfänger-Themen 1
M Eine Funktion zuweisen Java Basics - Anfänger-Themen 3
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
A Methoden Guten Tag , ich wollte so machen dass wenn meine frog an eine fly/bee geht dann an meine Tafel geht der zahl +1 hoch. Java Basics - Anfänger-Themen 2
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
J Beim Start des Programms zB. eine Linie in JPanel ausgeben Java Basics - Anfänger-Themen 4
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
S Eine Idee umsetzen ganz schnell!? Java Basics - Anfänger-Themen 68
I Grundsatzfrage: Belegt eine Referenz auf 'null' RAM, und wenn ja - wieviel ;-) ? Java Basics - Anfänger-Themen 5
jeff98 Wie kann man in Java eine Zeichenformation ausgeben? Java Basics - Anfänger-Themen 9
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
Thomas06 Wie kann man mithilfe von boolean herausfinden ob eine zahl durch 5 und 7 teilbart ist ? Java Basics - Anfänger-Themen 7
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
A Eclipse IDE - Wie bekomme ich eine ältere Version Java Basics - Anfänger-Themen 6
F Wie kann ich eine Funktion schreiben, die nur in bestimmten Fällen einen Wert zurückgibt? Java Basics - Anfänger-Themen 5
berserkerdq2 Warum muss man manchmal in der RUnmethode sleep in eine schleife tun? Java Basics - Anfänger-Themen 9
berserkerdq2 Findet eine parallele Verarbeitung in Java bei Threads erst statt, wenn man die Methoden auch synchronized? Und wie sieht bei Conditions aus? Java Basics - Anfänger-Themen 8
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
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
berserkerdq2 Zwei Klassen Erben von der Klasse A, die eine Klasse kann ich an Methoden übergeben, die als Parameter A haben, die andere nicht? Java Basics - Anfänger-Themen 3
berserkerdq2 Sende eine Nachricht an den Client und leere den Ausgabestorm, was ist damit genau gemeint? Java Basics - Anfänger-Themen 3
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
sserio Prüfen, ob eine Zahl eine periodische Zahl ist Java Basics - Anfänger-Themen 20
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
berserkerdq2 Warum soll ich shuffle nutzen, um bei Rückgabewert Collection eine Liste zurückzugeben? Java Basics - Anfänger-Themen 3
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
berserkerdq2 Überprüfen ob eine Schreibberechtigung auf ein file exisitert bzw. ob man dieses file löschen kann, wie? Java Basics - Anfänger-Themen 9
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
Avalon Warum funktioniert eine Bedingung und eine andere nicht? Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
X Hilfe beim Übertragen in eine For-Schleife Java Basics - Anfänger-Themen 1
H Eine Methode über Actionlistener beenden Java Basics - Anfänger-Themen 8
A Wenn eine Zahl durch 7 teilbar ist, soll statt der Zahl ein ‘*‘ angezeigt werden. java? Java Basics - Anfänger-Themen 47
U Warum gibt das eine Nullpointerexception? (Switch) Java Basics - Anfänger-Themen 6
U Warum kriege ich hier eine nullpointer exception, sehe den Fehler nicht (swing) Java Basics - Anfänger-Themen 1
K Warum gibt mir z. B. 40^128 eine Zahl? Ich dachte mit xor kann man nur booleanwerte erhalten, also prüfen ob etwas whar oder falsch ist? Java Basics - Anfänger-Themen 1
M Wie lassen sich Objektkonstanten initialisieren, wenn sie eine Bedingung erreichen? Java Basics - Anfänger-Themen 6
K Präzedenregeln in Java sagen, dass +expr und -expr vor + von Addition und - von Addition stehen, warum wird dann z. B. a+b als eine Addition ausgeführ Java Basics - Anfänger-Themen 7
M Wie schreibe ich eine if-Verzweigung um, so dass ein Bedingungsoperator benutzt wird? Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
M Wie kann eine Methode eine andere Methode um Werte wie z.B. 1 erhöhen? Java Basics - Anfänger-Themen 6
B Methoden Rekursiv festellen, ob eine Zahl gerade-oft vorkommt oder nicht Java Basics - Anfänger-Themen 4
M Wie kann ich eine Methode aus einem Interface in eine Klasse implementieren, so dass sie ihre Funktion ausführt? Java Basics - Anfänger-Themen 7
Igig1 Welche Werte sind als default Werte in einem Array, der als Datentyp eine Klasse hat? Java Basics - Anfänger-Themen 1
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
EchtKeineAhnungManchmal Hallo :) ich bekomme es nicht hin eine Fehlermeldung auszugeben über die GUI Java Basics - Anfänger-Themen 3
S Kann ich eine jar anschauen wie sie gecoded wurde? Java Basics - Anfänger-Themen 2
A Eine Textdatei auslesen Java Basics - Anfänger-Themen 16
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
Poppigescorn scan.nextInt() wiederholen bis eine Zahl eingeben wird Java Basics - Anfänger-Themen 7
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
B Programm, dass alle 3 Tage eine Webseite öffnet? Java Basics - Anfänger-Themen 20
N Variabel in eine class mit "extends JLabel" übertragen Java Basics - Anfänger-Themen 2
C Programm das feststellen kann, ob eine eingegebene Zahl einem Schaltjahr entspricht, richtig geschrieben? Java Basics - Anfänger-Themen 11
Vivien Auf eine Variable von einer anderen Klasse aus zugreifen Java Basics - Anfänger-Themen 3
B eine methode erstellen Java Basics - Anfänger-Themen 7
F Wann ist es eine Instanz und wann nicht? Java Basics - Anfänger-Themen 1
E Warum lässt sich eine Klasse nicht starten, wenn eine andere Klasse in dem Modul fehlerhaft ist? Java Basics - Anfänger-Themen 1
J Alle .java Dateien von einem Verzeichnis in eine Zip speichern Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben