Dieses Repository beinhaltet den kompletten Satz an Übungsaufgaben für das Modul "Datenbanktechnologien" an der HTW Berlin. Die Aufgaben basieren auf dem Anwendungsfall eines automatisierten Kühlschranksystems, in denen Blut-, Serum- und Urinproben gelagert werden können.
Importieren sie das Repository in ihren eigenen Github-Account und setzen sie die Sichtbarkeit auf "private", damit andere Gruppen nicht ihre Lösungen einsehen können. Klonen sie dann ihr Repository (nicht meines) und bearbeiten sie es mit der IDE ihrer Wahl (VS Code, IntelliJ, Eclipse)
Zur Bearbeitung der Aufgaben müssen sie das Datenmodell in ihrer eigenen Datenbank anlegen.
- Beschreibung des Datenmodells (pdf)
- SQL-Code zur Erzeugung der Tabellen und zum Einfügen der Daten (link)
Die Verwendung der Logging-Einstellungen wird in der Übung erläutert.
-Dorg.slf4j.simpleLogger.showThreadName="false"
-Dorg.slf4j.simpleLogger.logFile="System.out"
-Dorg.slf4j.simpleLogger.log.org.dbunit="error"
-Dorg.slf4j.simpleLogger.log.de.htwberlin="info"
Protokollstufen
- error
- warn
- info
- debug
Es gibt eine Übung zur Wiederholung von SQL, zwei Übungen zur Implementierung von datenbank-orientierten Diensten in Java und eine Übung zur Implementierung eines datenbank-orientierten Dienstes in PL/SQL.
Für die Dienste werden Test bereitgestellt, mit denen sie die Funktionsfähigkeit ihrer Lösungen überprüfen können. Bedenken Sie aber, dass eine erfolgreiche Ausführung aller Tests nicht automatisch die Korrektheit Ihrer Lösung sicherstellt. Tests können immer nur die Anwesenheit von Fehlern zeigen, nicht aber deren Abwesenheit. Das liegt daran, dass Tests im Allgemeinen nicht vollständig alle Fehlersituationen abdecken. In der Bewertung Ihrer Lösung ist daher der erfolgreiche Durchlauf aller Tests eine notwendige Bedingung zum Erreichen der vollen Punktzahl. Es kann aber trotzdem Punktabzug geben, falls Ihre Lösung Fehler enthält, die durch die Tests nicht aufgedeckt werden.
Im Laufe des Semesters kann jede Gruppe einmalig 2 Bonuspunkte durch die Präsentation von Lösungsbestandteilen der Übung 2 oder 3 erhalten. Es gelten folgende Bedingungen
- Die Punkte können als Ausgleich für Punktabzüge bei den abgegeben Lösungen dienen
- Sie können trotzdem nur insgesamt 40 Punkte in den Übungen erreichen
- Sollte die Summe regulärer Punkte plus Bonuspunkte 40 übersteigen wird auf 40 gekappt
Diese Übung dient zur Wiederholung von SQL und zur Einarbeitung in die Struktur der Daten im Proben-Kühlschranksystem. Die Bearbeitung dieser Übung ist freiwillig, eine Abgabe der Lösungen ist nicht erforderlich.
- SQL-Aufgaben (link)
Diese Übung dient zur Implementierung einfacher Dienste in Java. Dabei geht es im wesentlichen um die Verwaltung der Daten.
public interface ICoolingJdbc {
List<String> getSampleKinds();
Sample findSampleById(Integer sampleId);
void createSample(Integer sampleId, Integer sampleKindId);
void clearTray(Integer trayId);
}
Details zu den Diensten finden sie hier (link)
Diese Übung dient zur Implementierung eines komplexen Dienstes in Java. Dabei geht es um die Einlagerung von Proben unter Berücksichtigung von Verfallsdaten und Probengrößen.
public interface ICoolingService {
void transferSample(Integer sampleId, Integer diameterInCM);
}
Details zu dem Dienst finden sie hier (link)
Dieser Dienst soll in zwei Versionen implementiert werden:
- Standardimplementierung in einer Java-Datei CoolingService.java wie bei Übung 2
- Implementierung auf Grundlage eines Architekturmusters (Table-Data-Gateway, Row-Data-Gateway oder Data-Mapper) in einer Datei CoolingServiceDao.java und zusätzlichen Interfaces und Klassen zur Implementierung der DAOs
Diese Übung dient zur Implementierung eines komplexen Dienstes innerhalb des Datenbanksystems mit PL/SQL. Dabei soll der Dienst aus Übung 3 in diesem neuen Umfeld reimplementiert werden.
create or replace package cooling_service as
exc_data exception;
pragma exception_init(exc_data, -20001);
exc_cooling_system exception;
pragma exception_init(exc_cooling_system, -20002);
procedure transfer_sample(
p_sample_id sample.sampleid%type,
p_diameter_in_cm tray.diameterincm%type);
end cooling_service;
PL/SQL-Code zu dieser Übung finden sie hier (link)