VT-Hilfsspalten für automatisierte Joins |
Anfang Zurück Vor |
Letzte Änderung 13.02.2014
Für die Abfrage mehrerer Datenbanktabellen benötigen Sie immer nur eine einzige Virtuelle Tabelle als Ziel-Tabelle, in der das Abfrageergebnis zusammengeführt wird. In dieser müssen jedoch alle selektierten Spalten vorhanden sein. Um das zu erreichen, können Sie eine bereits vorhandene Virtuelle Tabelle mit allen noch fehlenden Spalten erweitern, oder Sie erzeugen speziell für das Abfrageergebnis eine neue Virtuelle Tabelle, die alle selektierten Spalten enthält.
Beispiel für Abfrage über 3 Tabellen:
Mit einer Abfrage auf die Tabelle Fahrzeuge sollen alle Fahrzeuge ausgegeben werden. Zu den Fahrzeugdaten soll von der Tabelle Modelle der Name des Modells und von der Tabelle Hersteller der Markenname dazu gejoint werden.
●DB:FAHRZEUGE ●DB:MODELLE ●DB:HERSTELLER
Geeignete Virtuelle Tabelle für das Abfrageergebnis: Die Virtuelle Tabelle Fahrzeuge kann durch Import der Datenbanktabelle Fahrzeuge automatisch generiert werden und ist i.d.R. bereits im Projekt vorhanden. Es fehlen jedoch noch Spalten für die Ausgabe von Modell- und Markenname.
●VT:FAHRZEUGE
Notwendige Erweiterung: Die Erweiterung der Virtuellen Tabelle mit den benötigten Spalten Modell und Marke können Sie mit wenigen Mausklicks im VT-Editor vornehmen.
●VT:FAHRZEUGE
1.Klicken Sie im Projektmanagement die Virtuelle Tabelle Fahrzeuge mit Doppelklick an, um diese im VT-Editor zu öffnen. 2.Klicken Sie im VT-Editor bei Spalten auf Erweitern, um die Virtuelle Tabelle Fahrzeuge mit Hilfsspalten zu erweitern. 3.Wählen Sie Datei > Speichern, um die Änderungen in der Datei zu speichern.
Durch die Erweiterung erhält die Virtuelle Tabelle nicht nur die notwendigen Spalten für die Ausgabe der dazu gejointen Daten, sondern auch die notwendigen Informationen zu den Relationen zwischen den Virtuellen Tabellen. Voraussetzung dafür ist jedoch, dass zwischen den betroffenen Virtuellen Tabellen, z.B. Fahrzeuge, Modelle und Hersteller, gültige Relationen im ER-Designer von XDEV 5 bestehen. In der Datenbank müssen dafür jedoch keine Relationen definiert werden.
Mit diesen Informationen ausgestattet ist die Virtuelle Tabelle nun in der Lage, Datenbankabfragen über alle betroffenen Tabellen automatisch durchzuführen. Sie müssen die Virtuelle Tabelle abschließend nur noch mit einer GUI-Komponente verknüpfen, welche Daten einer Virtuellen Tabelle anzeigen kann, u.a. XdevTable, XdevComboBox, XdevListBox, XdevTree etc. Die Verknüpfung kann sowohl im GUI-Builder per drag&drop, als auch programmatisch mit Hilfe der Methode setModel( ) erfolgen, z.B. table.setModel(Fahrzeuge.VT).
Mit dem VT-Editor lassen jeweils nur für die nächste Relationsebene Hilfsspalten generieren, z.B. Fahrzeuge > Modelle. Für weiterführende Relationen müssen Sie die erforderlichen Hilfsspalten händisch hinzufügen, z.B. für Hersteller.
1.Klicken Sie im Projektmanagement > Virtuellen Tabelle > Hersteller auf +, um die Spalten anzuzeigen. 2.Ziehen Sie die Spalte MARKE per drag&drop in den VT-Editor zwischen ID und MODELL_ID, um die Virtuelle Tabelle Fahrzeuge mit einer Hilfsspalte für die Ausgabe der Hersteller zu erweitern. 3.Wählen Sie Datei > Speichern, um die Änderungen in der Datei zu speichern.
|