AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Tabellen aus verschiedenen Datenbänke in einem DBGrid
Thema durchsuchen
Ansicht
Themen-Optionen

Tabellen aus verschiedenen Datenbänke in einem DBGrid

Ein Thema von erich.wanker · begonnen am 22. Jan 2020 · letzter Beitrag vom 23. Jan 2020
Antwort Antwort
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
464 Beiträge
 
Delphi XE4 Professional
 
#1

Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 14:03
Datenbank: Firebird • Version: 2.1 • Zugriff über: ZeosLIB
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?
Erich Wanker - for life:=1971 to lebensende do begin ..
O
/H\
/ \
  Mit Zitat antworten Zitat
stifflersmom

Registriert seit: 8. Dez 2005
Ort: 24994 Holt
381 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#2

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 14:28
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
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 14:32
Hallo,
Zitat:
wie erkenne ich ob ich nun einen Record aus Database1 oder Database2 habe
Select 1, Name From DBName1.Tab1
Union
Select 2, Name From DBName1.Tab2

https://firebirdsql.org/manual/ufb-cs-multidb.html

DBName1.Tab1 war ein Test
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.599 Beiträge
 
Delphi 12 Athens
 
#4

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 14:34
Wäre hier nicht eher eine UNION das Mittel der Wahl?
Zitat:
Ein UNION verkettet zwei oder mehr Datasets und erhöht so die Anzahl der Zeilen, nicht aber die Anzahl der Spalten. Datasets, die an einer UNION teilnehmen, müssen die gleiche Anzahl von Spalten haben, und Spalten an entsprechenden Positionen müssen vom selben Typ sein. Abgesehen davon können sie völlig unabhängig sein.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#5

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 14:58
Hallo,
mit Union kann man aber nicht verschiedene DB's verknüpfen,
siehe mein Link.

Es sei denn, FB kann das mittlerweise.
FB2.5: http://www.firebirdfaq.org/faq16/

Aber: Wird reden hier ja von FB2.1.
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von TRomano
TRomano

Registriert seit: 24. Nov 2004
Ort: Düsseldorf
194 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 15:06
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 ...
Thomas Forget
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#7

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 15:16
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.
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.314 Beiträge
 
Delphi 12 Athens
 
#8

AW: Tabellen aus verschiedenen Datenbänke in einem DBGrid

  Alt 22. Jan 2020, 15:03
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.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 02:22 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