AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi DBGrid und verknüpfte Tabelle
Thema durchsuchen
Ansicht
Themen-Optionen

DBGrid und verknüpfte Tabelle

Ein Thema von Uwe 111 · begonnen am 18. Mär 2006 · letzter Beitrag vom 19. Mär 2006
Antwort Antwort
Seite 1 von 2  1 2      
Uwe 111

Registriert seit: 29. Nov 2005
61 Beiträge
 
#1

DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 19:12
Datenbank: BDE • Zugriff über: TTable & TDatasouce
Hallo

Mein Problem ist, ich habe zwei tabellen verknüpft und möchte das beide Tabellen im DBGrid angezeigt werden.
Wie macht man das am besten

MfG
Uwe 111
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 19:47
Hallo Uwe,

du schreibst von Verknüpfung und gibst TTable als verwendete Komponente an - dann hast du eine Master-Detail-Beziehung eingerichtet? Verwende eine TQuery und verknüpfe beide Tabellen über einen JOIN - die Query kannst du dann genau wie eine Tabelle als DataSet deiner DataSource angeben.

Delphi-Quellcode:
begin
  with Query do
  begin
    SQL.Text := 'select a.kunde, a.nummer, a.datum, p.nummer, p.artikel, p.anzahl '
              + 'from auftraege a, positionen p '
              + 'where a.id = p.auftrag '
              + 'order by a.datum';
    Open;
    // ...
  end;
end;
Grüße vom marabu
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 19:47
Statt TTable ein TQuery verwenden. Dort einen SQL-Join über beide Tabellen erzeugen.

[edit:]Marabu war wieder mal schneller! [/edit]
Markus Kinzler
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#4

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 20:08
Hi Markus,

das ist nur gerecht - was glaubst du denn wie lange ich an meinem Beitrag gefeilt habe?

Verschmitzte Grüße nach Heilbronn

marabu
  Mit Zitat antworten Zitat
Uwe 111

Registriert seit: 29. Nov 2005
61 Beiträge
 
#5

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 21:39
Hallo

Ich komme mit SQL nicht klar, geht es auch nicht anders?

MfG
Uwe 111
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 21:44
Poste mal die Beschreibungen der beiden Tabellen, dann können wir die helfen. SQL ist wirklich nicht schwer
Markus Kinzler
  Mit Zitat antworten Zitat
Uwe 111

Registriert seit: 29. Nov 2005
61 Beiträge
 
#7

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 21:56
Hallo

Tabelle1
Nr_ID = Primärkey
Name
Vorname

Tabelle2
Adressen_Id = Primärkey
PLZ
ORT
Strasse

MfG
Uwe 111
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: DBGrid und verknüpfte Tabelle

  Alt 18. Mär 2006, 22:07
Bei der 2. tabelle fehlt irgendwie der Foreign Key, mit dem die Adresse mit dem Namen verknüpft ist.

Tabelle1
Nr_ID = Primärkey
Name
Vorname

Tabelle2
Adressen_Id = Primärkey
Name_Id = Foreign Key auf Tabelle1.Nr_ID
PLZ
ORT
Strasse

Dann würde die SQL-Abfrage

SQL-Code:
select
    t1.Nr_ID, t1.Name, t1.Vorname,
    t2.Adressen_Id, t2.PLZ, t2.Ort, t2.Strasse
from
    Tabelle1 t1, Tabelle2 t2
where
    t2.Name_ID = t1.Nr_ID;
Noch besser wäre es aber eine Zwischentabelle zu generieren, die eien n zu m Beziehung ermöglicht.

Tabelle3
ID(PK)
Nr_ID (FK)
Adressen_ID(FK)

dann würde die Abfrage so aussehen:

SQL-Code:
select
    t1.Nr_ID, t1.Name, t1.Vorname,
    t2.Adressen_Id, t2.PLZ, t2.Ort, t2.Strasse
from
    Tabelle3 t3, Tabelle1 t1, Tabelle2 t2,
where
    t1.Nr_ID = t3.Nr_ID and
    t2.Adressen_ID = t3.Adressen_ID;
Markus Kinzler
  Mit Zitat antworten Zitat
Uwe 111

Registriert seit: 29. Nov 2005
61 Beiträge
 
#9

Re: DBGrid und verknüpfte Tabelle

  Alt 19. Mär 2006, 17:02
Hallo

Erstmal danke. Das mit der SQL habe ich hinbekommen, aber jetzt kann ich nicht mehr editieren.

MfG
Uwe 111
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#10

Re: DBGrid und verknüpfte Tabelle

  Alt 19. Mär 2006, 17:24
Ein Query ist nur direkt bearbeitbar, wenn die Datenbank einen updateable Cursor unterstützt. Die BDE tut das m.W. nicht. Wenn die Abfrage, wie in deinem Fall aus einem Join besteht ist es nochmal schwerer. Wenn die Änderungen sich auf eine Tabelle beziehen kannst du wie folgt vorgehen:
Füge eine TUpdateQuery-Komponente hinzu, füge die gewuünschten DML-Queries ein ( INSERT, UPDATE, DELETE) und Verknüpfe den Query mit der Eigenschaft UpdateObject mit dieser Kompoenente.
Sonst eigene Query/Table-Kompoenente für die Änderungen and den 2/3 Tabellen.
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 00:03 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz