![]() |
Datenbank: Firebird • Version: 2.1 • Zugriff über: ZeosLIB
Tabellen aus verschiedenen Datenbänke in einem DBGrid
Hallo,
wie kann ich in einem Grid Daten aus zwei Datenbänke darstellen? Tabelle1 ist in beiden Datenbänken vorhanden und hat TEILWEISE gleiche Felder! Database1 - Tabelle1 hat Felder: INR (unique Integer key) Eintrag (String) Bemerkung (String) Messwert (double) Database2 - Tabelle1 hat Felder: INR (unique Integer key) Eintrag (String) Bemerkung (String) Baugruppe(String) Jetzt will ich die "gemeinsamen Felder" - die beide Tabellen aufweisen in einem Grid darstellen. ZConnection1 -> Database1.fdb -Tabelle1 ZConnection2 -> Database2.fdb -Tabelle1 ZQuery1.Connection:= UniMainModule.ZConnection1 ZQuery2.Connection:= UniMainModule.ZConnection2 ZQuery1.SQL.Clear; ZQuery1.sql.append(' SELECT ???? INR,EINTRAG,BEMERKUNG from ???? UND Wenn ich in DbGrid einen doppelklick auf einen Eintrag mache - wie erkenne ich ob ich nun einen Record aus Database1 oder Database2 habe? |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Sind beide Datenbanken auf dem selben Server und greifen da dieselben Credentials?
Dann könntest Du da vielleicht schon mit einer Query erschlagen: select t1.spalte1, t2.spalte1, t1.spalte2, t2.spalte2 from dbname1.tabelle t1, dbame.tabelle t2 where t1.id=t2.id |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Hallo,
Zitat:
Union Select 2, Name From DBName1.Tab2 ![]() DBName1.Tab1 war ein Test |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Wäre hier nicht eher eine
![]() Zitat:
|
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Hallo,
mit Union kann man aber nicht verschiedene DB's verknüpfen, siehe mein Link. Es sei denn, FB kann das mittlerweise. FB2.5: ![]() Aber: Wird reden hier ja von FB2.1. |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Kann FireDAC nicht auch LocalSQL auf GUI-Komponenten?
Dann ein SELECT das aus die zwei anderen QueryComponenten geht. Datenbank übergreifend (im selben DB-Server) sollten alle DBMS können. Einige DBMS bieten auch Funktionen, um serverseitig auf einen anderen DB-Server (sogar auf komplett andere DBMS) zuzugreifen. |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Da Firebird es nicht kann wird dir wohl nichts anderes übrig bleiben, beide Queries zu öffnen und in eine definierte Struktur eines ClientDataSets zu laden.
Dort kannst du ein zusätzliches Feld anlegen mit dem Namen woher die Daten stammen. Da ClientDataSet kannst du mit einem TDataSource verbinden und die Komponente wiederum mit deinem Grid. Umständlich, aber es geht.Nur wenn Du dann im Grid auch noch Ändern/Erfassen/Löschen willst wird es tricky ... |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Hallo,
wenn eh alles so umständlich ist, kann er ja gleich ein normales TStringGrid nehmen und die Update-Methoden über eigene Queries machen, je eine pro DB. |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Man sieht, es ist nicht vorgesehen. Dann sehe ich da noch in den verschiedenen DB die Definition / Nutzung von eindeutigen Feldern.
Ein Sinn einer DB ist es ja, der Anforderung "unique" einen Rahmen zu geben und diesen einzuhalten. Paart man 2 DB, so ist es nichts mehr mit Eindeutigkeiten. Da sollte doch die Frage erlaubt sein, was eigentlich der Sinn der Aktion sein soll. |
AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid
Wie sollen die eigentlich zusammen?
Untereinander (UNION) oder nebeneinander (JOIN). [edit] OK, soll untereinander. Beim JOIN können die Felder des zweiten DataSets als CalcFields an das Andere angehängt werden. Aber beim UNION bleibt nur das Umkopieren, in ein MemoryDataSet (z.B. TClientDataSet), bzw. direkt in ein nicht-datensensitives Grid. Für's LiveBinding gibt es bestimmt noch elegantere Wege, vor allem da dort eh das DataSet über eine Liste umgeleitet wird. Zitat:
(kann auch ausgeblendet sein und für die Hintergrundfarbe der Zeilen genutzt werden) Für den JOIN hätte man bestimmt auch die NestedDataSets missbrauchen können. ![]() @faq16: Man, muß der Kleine schon alt sein. Fehlt ja nur noch dass "You cannot do JOINs with tables in different database" behoben wird. ![]() Das Ding lässt sich aufrufen und in mehrere Variablen schreiben. Also Zeile für Zeile in einer StoredProc aus der anderen Datenbank holen und an das erste Select anjoinen? :lol: ![]() |
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:34 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz