samedi 23 mai 2015
Derby/JavaDB Datenbank füllen
Posted on 16:13 by verona
Hi,
ich möchte, dass in einer GUI(die schon fertig ist) der Vorname, Nachname, Geburtsdatum und klasse und geschlecht eingegeben bzw. angewählt werden.
Die Daten einzugeben funktioniert prima (über System.out.println() wird alles so ausgegeben, wie ich es will)
Allerdings klappt das nicht, die Daten in die Datenbank zu schreiben (ich glaube der hat mit dem Datum probleme).
Hier erstmal die anbindung (da sollte eigentlich kein Fehler sein, da ich die Daten aus der Datenbank ja lesen kann)
Und hier die Problemstelle:
dass ist die Fehlermeldung:
DB-Verbindungsfehler: java.sql.SQLSyntaxErrorException: Syntaxfehler: Encountered "May" at line 1, column 81.
Ich verstehe jetzt ehrlichgesagt nicht, warum der rum meckert, da das DB-Format für das datum ja yyyy-mm-dd ist.
wisst ihr vielleicht, wo der Fehler liegt?
Falls es eine Rolle spielt, ich benutze NetBeans...
MfG
mirisbowring
ich möchte, dass in einer GUI(die schon fertig ist) der Vorname, Nachname, Geburtsdatum und klasse und geschlecht eingegeben bzw. angewählt werden.
Die Daten einzugeben funktioniert prima (über System.out.println() wird alles so ausgegeben, wie ich es will)
Allerdings klappt das nicht, die Daten in die Datenbank zu schreiben (ich glaube der hat mit dem Datum probleme).
Hier erstmal die anbindung (da sollte eigentlich kein Fehler sein, da ich die Daten aus der Datenbank ja lesen kann)
Java Code:
-
public void DB() {
-
try {
-
//Datenbanktreiber wird geladen
-
Class.forName("org.apache.derby.jdbc.ClientDriver");
-
}
-
try {
-
//User und Passwort werden gesetz und Pfad zur Datenbank
-
//Verbindung mit der Datenbank wird aufgebaut
-
}
-
}
Und hier die Problemstelle:
Java Code:
-
private void jButton8ActionPerformed(java.awt.event.ActionEvent evt) { //Hier wird der angeklickte Wert gespeichert, um ihn später einsetzen zu können. das println ist zum nachverfolgen, ob alles sauber läuft, wenn die Konsole läuft.
-
Inputg = (String) jComboBox10.getSelectedItem(); //hierbei handelt es sich um die combobox mit dem geschlecht
-
//System.out.println(Inputg);
-
//Der String wird zu m bzw. w umgeändert, da die datenbank lediglich diese Buchstaben für das Geschlecht gespeichert hat.
-
if (Inputg.contains(weibl)) {
-
Inputg = "w";
-
//System.out.println(Inputg);
-
} else if (Inputg.contains(man)) {
-
Inputg = "m";
-
//System.out.println(Inputg);
-
}
-
-
//Zahlen aus dem Datumfeldern werden eingelesen
-
//Namen werden ausgelesen
-
vorname = jTextField14.getText();
-
nachname = jTextField16.getText();
-
//System.out.println(name);
-
//es wird eine Variable 'y' mit dem Wert 1 erstellt und vom Monat abgezogen, da der Gregorianische Kalender von 0-11 geht|nicht aber von 1-12: Und da der nutzer das nicht beachten soll, muss der Integer einfach mit 1 Subtrahiert werden.
-
int y;
-
int z;
-
y = 1;
-
z = monat - y;
-
//GregorianCalender ermöglicht einen Datum Datentyp
-
//standartmäßig verwendet der GregorianCalender alle Einheiten (also auch Zeit, etc.) aber wir brauchen nur das Datum, demnach geben wir ihm das Schema vor
-
//wird für die Konsole ausgegeben
-
-
//SQL
-
try
-
{
-
stmtdbbi = dbverbindung.createStatement();
-
stmtdbbi.executeUpdate("INSERT INTO schueler (name, geschlecht, geburtsdatum) "
-
+"VALUES ("+name+", "+Inputg+", "+date+")");
-
}
-
}
dass ist die Fehlermeldung:
DB-Verbindungsfehler: java.sql.SQLSyntaxErrorException: Syntaxfehler: Encountered "May" at line 1, column 81.
Ich verstehe jetzt ehrlichgesagt nicht, warum der rum meckert, da das DB-Format für das datum ja yyyy-mm-dd ist.
wisst ihr vielleicht, wo der Fehler liegt?
Falls es eine Rolle spielt, ich benutze NetBeans...
MfG
mirisbowring
Derby/JavaDB Datenbank füllen
Categories: Derby/JavaDB Datenbank füllen
Inscription à :
Publier les commentaires (Atom)
0 commentaires:
Enregistrer un commentaire