Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Empfohlene Antworten

Veröffentlicht

Hey Leute! Ich zeig euch erst die Aufgabenstellung, anschließend meinen bereits geschriebenen Code und Anschließend wo mein Problem ist ?

Aufgabe:

1. Im Datenbanksystem eine Tabelle „Kunde“ erstellen mit den Spalten Kundennummer, Nachname, Vorname, Straße, Postleitzahl, Ort, wobei die Kundenummer der eindeutige Schlüssel sein soll.

2. Im Datenbanksystem zwei Kunden anlegen die alle Spalten gefüllt haben.

3. In Eclipse ein Java-Projekt anlegen mit einer Klasse Start, die eine Methode public static void main(String[] args) hat.

4. Die externe Bibliothek sqljdbc4-4.0.jar für den Datenbankzugriff in das Projekt einbinden.

5. Eine Java-Klasse „Kunde“ anlegen, die dieselben Eigenschaften wie die Tabelle hat. Get- und Set-Methoden zu diesen Eigenschaften anlegen.

6. In der Klasse Start in der Main-Methode soll per JDBC eine Datenbankverbindung zu der Datenbank erstellt werden und das Select-Statement: „SELECT * FROM Kunde“ aufgerufen werden.  

7. Pro Zeile des Ergebnisses soll ein Java-Objekt „Kunde“ erstellt werden und die Eigenschaften mit den Werten aus der Tabelle gefüllt werden. Diese Kunden sollen in einer Liste gespeichert werden.

8. Die Liste soll einmal durchlaufen werden und pro Kunde der Vorname, Nachname und die Kundennummer in einer Zeile in der Konsole ausgegeben werden. 

Mein Code:

public class Main {
    public static void main(String args[]) {
        
            try {
                Class.forName("com.mysql.jdbc.Driver");
                Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306", "root", "area51");
                Statement stmt = con.createStatement();
                DatabaseMetaData met = con.getMetaData();
                ResultSet rs = met.getCatalogs();

                int i = 1;
                boolean gefunden = false;

                while (rs.next() && !gefunden) {
                    if (rs.getString(i).equals("PraktikumAufgabe")) {
                        gefunden = true;
                        i++;
                    }
                }
                if (!gefunden) {
                    createDB();
                }
                
                rs = stmt.executeQuery("select * from Kunde");
                
                
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }
    }
    
    public static void createDB(){

        try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/", "root", "area51");
            Statement stmt = con.createStatement();

            stmt.executeUpdate("CREATE DATABASE PraktikumAufgabe");
            stmt.executeUpdate(
                    "CREATE TABLE dbtest.Kunde(Kundennummer integer primary key Auto_increment, Vorname varchar(20) , Nachname varchar(26), Straße varchar(30) Postleitzahl integer(5), Ort varchar(30))");
            stmt.executeUpdate("INSERT INTO dbtest.namen VALUES(1, 'peter','stein','ludwigstraße 23','86551','Aichach')");
            stmt.executeUpdate("INSERT INTO dbtest.namen VALUES(1, 'markus','maier','Waldweg 30','86551','Aichach')");

        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        }
    }
}

 

Ich häng jetzt bei Aufgabe Nr. 7

Mir ist nicht Klar wie ich pro Zeile der Konsolenausgabe in mein Objekt Kunde speichern kann ?

Jemand einen Vorschlag?

Alte Forensitte: ein Problem: Ein Thread.

Hier geht es weiter:

 

  • Gast hat dies Thema gesperrt
Gast
Dieses Thema ist für weitere Antworten geschlossen.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.