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:
public void DB() {
try {
//Datenbanktreiber wird geladen
Class.forName("org.apache.derby.jdbc.ClientDriver");
System.out.println("eingabepanel Treiber erfolgreich geladen...");
} catch (ClassNotFoundException e) {
System.out.println("eingabepanel Fehler beim Laden des Treibers" + e);
System.exit(0);
}
try {
//User und Passwort werden gesetz und Pfad zur Datenbank
String host = "jdbc:derby://localhost:1527/Datenbank";
String username = "login";
String userpw = "login";
//Verbindung mit der Datenbank wird aufgebaut
dbverbindung = DriverManager.getConnection(host, username, userpw);
System.out.println("eingabepanel Verbindung erfolgreich...");
} catch (SQLException e) {
System.out.println("eingabepanel DB-Verbindungsfehler: " + e);
System.exit(0);
}
}
Und hier die Problemstelle:
Java:
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.
String weibl = "weiblich";
String man = "männlich";
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
jahr = Integer.parseInt(jTextField18.getText());
monat = Integer.parseInt(jTextField17.getText());
tag = Integer.parseInt(jTextField15.getText());
//Namen werden ausgelesen
vorname = jTextField14.getText();
nachname = jTextField16.getText();
String name = nachname + ", " + vorname;
//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
GregorianCalendar geburtsdatum = new GregorianCalendar(jahr, z, tag);
Date date = geburtsdatum.getTime();
//standartmäßig verwendet der GregorianCalender alle Einheiten (also auch Zeit, etc.) aber wir brauchen nur das Datum, demnach geben wir ihm das Schema vor
SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
//wird für die Konsole ausgegeben
System.out.println(sdf.format(date));
//SQL
try
{
stmtdbbi = dbverbindung.createStatement();
stmtdbbi.executeUpdate("INSERT INTO schueler (name, geschlecht, geburtsdatum) "
+"VALUES ("+name+", "+Inputg+", "+date+")");
String SQLcontrol = ("SELECT * FROM schueler");
System.out.println(SQLcontrol);
} catch (Exception e) {
System.out.println("dbbearbeitenpanel DB-Verbindungsfehler: " + e);
System.exit(0);
}
}
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