CodeGym/Java-Kurse/All lectures for DE purposes/Verwandtes Projekt: Hibernate (2)

Verwandtes Projekt: Hibernate (2)

Verfügbar

Heute besteht unsere Aufgabe darin, das zweite Projekt zum Thema Hibernate abzuschließen. Sein Kern besteht darin, die Struktur der Datenbank zu verstehen, die Entität vorhandenen Tabellen zuzuordnen und die Mindestfunktionalität hinzuzufügen, um zu überprüfen, ob die Zuordnung korrekt erfolgt.

Jetzt ausführlicher:

  1. Laden Sie die Dump-Datei herunter und stellen Sie sie auf Ihrem lokalen Computer bereit. Als Datenbank verwenden wir eine Testdatenbank, die als Beispiel zusammen mit dem MySQL-Installationspaket verteilt wird. Der Dump wird benötigt, um den Zustand der Datenbank zu korrigieren, da wir nicht garantieren können, dass er sich an einem Tag, Monat oder Jahr nicht ändert.
  2. Wir werden keine Projektvorlage haben, also erstellen Sie das Projekt selbst. Es sollte ein Maven-Projekt mit allen erforderlichen Abhängigkeiten sein ( hibernate-core-jakarta , mysql-connector-java , p6spy ).
  3. Binden Sie unsere lokal bereitgestellte Datenbank als Datenquelle in Idea ein. Setzen Sie anschließend im Reiter „Datenbank“ den Cursor auf das Filmschema und drücken Sie die Tastenkombination Alt+Ctrl+Shift+U(funktioniert nur in der Ultimate-Version). Dadurch wird die Struktur des gesamten Filmschemas angezeigt (mit Spaltennamen, Schlüsseln usw.). Sieht aus wie das:

    Ich stimme zu, es ist nicht sehr angenehm anzusehen. Deaktivieren Sie die Anzeige des Titels aller Spalten und Kommentare:

    Als Ergebnis erhalten Sie ein Datenbankschema, das bereits analysiert werden kann:

  4. Die Strecke sieht kompliziert aus, aber nicht alles ist so schlecht. Um die Struktur der Datenbank zu analysieren, müssen Sie herausfinden, wo Sie beginnen sollen. Es gibt keine einzige richtige Antwort, aber ich würde empfehlen, mit einer Tabelle zu beginnen film. Nehmen wir als Beispiel ein paar Beziehungen:
    • Die Beziehung zwischen Tabellen filmund film_textist eine explizite OneToOne- Beziehung , da die Tabelle über film_textein Feld verfügtfilm_idNICHTbezieht sich auf eine ID aus einer Tabelle film(kein Fremdschlüssel). Aber dem Namen und der Logik nach sollte diese Verbindung bestehen. Darüber hinaus fungiert film_textdas Feld in der Tabelle film_idals Primärschlüssel, der garantiert, dass einem „Film“ maximal ein „Filmtext“ entspricht.
    • Schauen wir uns nun die Tabellen filmund an category. Logischerweise kann ein Film mehrere Kategorien haben. Und eine Kategorie, vielleicht verschiedene Filme. Darüber hinaus gibt es zwischen diesen beiden Tabellen eine Zwischenverbindungstabelle film_category. Basierend auf all dem oben Gesagten handelt es sich um eine explizite ManyToMany- Beziehung .
    • Wir schauen uns die Tabellen an filmund language. Aus logischer Sicht kann der Film in verschiedene Sprachen übersetzt sein und verschiedene Filme können in derselben Sprache sein. Das heißt, ManyToMany bietet sich an . Wenn wir uns jedoch den Inhalt der Tabelle ansehen film, können wir erkennen, dass jede Zeile der Tabelle ein einzigartiger Film ist. Und es gibt nur ein Feld „ Sprache_ID“ in der Zeile (es gibt auch „Originalsprache_ID“, aber in allen Datensätzen ist es null, sodass wir es ignorieren können). Das heißt, ein Film kann nur eine Sprache haben. Und eine Sprache, vielleicht verschiedene Filme. Die Verbindung ist ManyToOne (die Verbindung ist vom Film zur Sprache gerichtet).
  5. Die Hauptaufgabe besteht nun darin, alle notwendigen Entitätsklassen zu erstellen und sie auf die Schematabellen abzubilden movie.
  6. Fügen Sie eine Methode hinzu, die einen neuen Kunden (Kundentabelle) mit allen abhängigen Feldern erstellen kann. Vergessen Sie nicht, die Methode transaktional zu gestalten (um nicht in die Situation zu geraten, dass die Adresse des Käufers in der Datenbank erfasst wird, der Käufer selbst jedoch nicht).
  7. Fügen Sie eine Transaktionsmethode hinzu, die das Ereignis „Der Kunde hat einen zuvor ausgeliehenen Film zurückgegeben“ beschreibt. Wählen Sie ein beliebiges Käufer- und Mietereignis Ihrer Wahl. Die Bewertung des Films muss nicht neu berechnet werden.
  8. Fügen Sie eine Transaktionsmethode hinzu, die das Ereignis beschreibt: „Der Käufer ging zum Laden (Laden) und mietete (Miet-)Inventar (Inventar) dort.“ Gleichzeitig leistete er eine Zahlung (Zahlung) an den Verkäufer (Mitarbeiter). Film (durch Inventar) wählen Sie nach Ihrem Ermessen. Die einzige Einschränkung besteht darin, dass der Film leihbar sein muss. Das heißt, es sollten entweder überhaupt keine Inventardatensätze in der Vermietung vorhanden sein oder die Spalte „return_date“ der Tabelle rentalfür die letzte Vermietung dieses Inventars sollte ausgefüllt sein.
  9. Fügen Sie eine Transaktionsmethode hinzu, die das Ereignis beschreibt: „Ein neuer Film wurde gedreht und wurde zum Ausleihen verfügbar.“ Film, Sprache, Schauspieler, Kategorien usw. wählen Sie nach Ihrem Ermessen.
  10. Die Tabellenstruktur kann nicht geändert werden. Aber Sie müssen Verbesserungsvorschläge machen. Wir haben eine problematische Stelle in Absatz 4 identifiziert (Fehlen eines Fremdschlüssels in der Tabelle film_textim film_idTabellenfeld film). Schauen Sie, ob es noch solche „Fehler“ in der Datenbankstruktur gibt. Wenn ja, fügen Sie eine Readme-Datei zum Stammverzeichnis des Projekts hinzu und beschreiben Sie diese Fehler.

Projektanalyse:

Kommentare
  • Beliebt
  • Neu
  • Alt
Du musst angemeldet sein, um einen Kommentar schreiben zu können
Auf dieser Seite gibt es noch keine Kommentare