samedi 23 mai 2015

Derby/JavaDB Datenbank füllen

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)

Java Code:

  1. public void DB() {
  2. try {
  3. //Datenbanktreiber wird geladen
  4. Class.forName("org.apache.derby.jdbc.ClientDriver");
  5. System.out.println("eingabepanel Treiber erfolgreich geladen...");
  6. System.out.println("eingabepanel Fehler beim Laden des Treibers" + e);
  7. System.exit(0);
  8. }
  9. try {
  10. //User und Passwort werden gesetz und Pfad zur Datenbank
  11. String host = "jdbc:derby://localhost:1527/Datenbank";
  12. String username = "login";
  13. String userpw = "login";
  14. //Verbindung mit der Datenbank wird aufgebaut
  15. dbverbindung = DriverManager.getConnection(host, username, userpw);
  16. System.out.println("eingabepanel Verbindung erfolgreich...");
  17. } catch (SQLException e) {
  18. System.out.println("eingabepanel DB-Verbindungsfehler: " + e);
  19. System.exit(0);
  20. }
  21. }



Und hier die Problemstelle:

Java Code:

  1. 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.
  2. Inputg = (String) jComboBox10.getSelectedItem(); //hierbei handelt es sich um die combobox mit dem geschlecht
  3. //System.out.println(Inputg);
  4. //Der String wird zu m bzw. w umgeändert, da die datenbank lediglich diese Buchstaben für das Geschlecht gespeichert hat.
  5. String weibl = "weiblich";
  6. String man = "männlich";
  7. if (Inputg.contains(weibl)) {
  8. Inputg = "w";
  9. //System.out.println(Inputg);
  10. } else if (Inputg.contains(man)) {
  11. Inputg = "m";
  12. //System.out.println(Inputg);
  13. }
  14.  
  15. //Zahlen aus dem Datumfeldern werden eingelesen
  16. jahr = Integer.parseInt(jTextField18.getText());
  17. monat = Integer.parseInt(jTextField17.getText());
  18. tag = Integer.parseInt(jTextField15.getText());
  19. //Namen werden ausgelesen
  20. vorname = jTextField14.getText();
  21. nachname = jTextField16.getText();
  22. String name = nachname + ", " + vorname;
  23. //System.out.println(name);
  24. //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.
  25. int y;
  26. int z;
  27. y = 1;
  28. z = monat - y;
  29. //GregorianCalender ermöglicht einen Datum Datentyp
  30. GregorianCalendar geburtsdatum = new GregorianCalendar(jahr, z, tag);
  31. Date date = geburtsdatum.getTime();
  32. //standartmäßig verwendet der GregorianCalender alle Einheiten (also auch Zeit, etc.) aber wir brauchen nur das Datum, demnach geben wir ihm das Schema vor
  33. SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
  34. //wird für die Konsole ausgegeben
  35. System.out.println(sdf.format(date));
  36.  
  37. //SQL
  38. try
  39. {
  40. stmtdbbi = dbverbindung.createStatement();
  41. stmtdbbi.executeUpdate("INSERT INTO schueler (name, geschlecht, geburtsdatum) "
  42. +"VALUES ("+name+", "+Inputg+", "+date+")");
  43. String SQLcontrol = ("SELECT * FROM schueler");
  44. System.out.println(SQLcontrol);
  45. } catch (Exception e) {
  46. System.out.println("dbbearbeitenpanel DB-Verbindungsfehler: " + e);
  47. System.exit(0);
  48. }
  49. }


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

0 commentaires:

Enregistrer un commentaire