AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL - mehrere Tabellen verbinden
Thema durchsuchen
Ansicht
Themen-Optionen

SQL - mehrere Tabellen verbinden

Ein Thema von API · begonnen am 26. Aug 2011 · letzter Beitrag vom 26. Aug 2011
Antwort Antwort
API

Registriert seit: 18. Apr 2004
637 Beiträge
 
#1

SQL - mehrere Tabellen verbinden

  Alt 26. Aug 2011, 13:29
Datenbank: Access • Version: 2010 • Zugriff über: -
Hallo,

Ich versuche 3 Tabellen miteinander zu verbinden.

Aus der Tabelle Personen sollen alle Datensätze angezeigt werden (left join), danach jene Datensätze der anderen 2 Tabellen angehängt werden, welche mit den IDs übereinstimmen.

Irgendwas stimmt nicht mit den Joins, identische Datensätze werden ausgegeben:

Zitat:
Person1, Wert1, Wert2
Person1, Wert1, Wert2
Person1, Wert1, Wert2
Wie muss das SQL abgeändert werden, so dass jede Person nur einmal vorkommt?

Code:
SELECT Personen.Nachname, Tabelle_2.Wert1, Tabelle_3.Wert2
FROM (Personen LEFT JOIN Tabelle_2 ON Personen.ID1 = Tabelle_2.ID1) LEFT JOIN Tabelle_3 ON Personen.ID2 = Tabelle_3.ID2;
1) Tabelle: Personen
Feld: Nachname
Feld: ID1
Feld: ID2

2) Tabelle: Tabelle_2
Feld: Wert1
Feld: ID1

3) Tabelle: Tabelle_3
Feld: Wert2
Feld: ID2
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#2

AW: SQL - mehrere Tabellen verbinden

  Alt 26. Aug 2011, 13:34
Als Erstes fällt mir DISTINCT ein.
SQL-Code:
SELECT DISTINCT(Personen.Nachname, Tabelle_2.Wert1, Tabelle_3.Wert2)
FROM ...
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Alaitoc

Registriert seit: 24. Okt 2008
263 Beiträge
 
Delphi 7 Enterprise
 
#3

AW: SQL - mehrere Tabellen verbinden

  Alt 26. Aug 2011, 13:36
Da war wohl jemand ne Sekudne schneller

Jepp DISTINCT sollte dir weiterhelfen

Damit mein Beitrag nicht völlig umsonst ist, eine ganz hilfreiche Seite für SQL:
http://www.sql-und-xml.de/sql-tutorial/

MfG Alaitoc

Geändert von Alaitoc (26. Aug 2011 um 13:37 Uhr) Grund: Nachtrag
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: SQL - mehrere Tabellen verbinden

  Alt 26. Aug 2011, 13:36
SQL-Code:
SELECT
    Personen.Nachname,
    Tabelle_2.Wert1,
    Tabelle_3.Wert2
FROM
    Personen
        LEFT JOIN Tabelle_2 ON Tabelle_2.ID1 = Personen.ID1
        LEFT JOIN Tabelle_3 ON Tabelle_3.ID2 = Personen.ID2;
Markus Kinzler
  Mit Zitat antworten Zitat
API

Registriert seit: 18. Apr 2004
637 Beiträge
 
#5

AW: SQL - mehrere Tabellen verbinden

  Alt 26. Aug 2011, 18:33
DISTINCT scheint die Lösung zu sei, habe überhaupt nicht daran gedacht, so fixiert war ich auf die JOINS und dachte, es liege an dessen Konstruktion...

@Markus: Dein Vorschlag gibt ein Fehler:

Zitat:
Syntax error (missing operator) in query expression 'Tabelle_2.ID1 = Personen.ID1
LEFT JOIN Tabelle_3 ON Tabelle_3.ID2 = Personen.ID'.
  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 05:00 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