Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi SQL + 2 Tabellen vereinen und alle Einträge ausgeben (https://www.delphipraxis.net/127757-sql-2-tabellen-vereinen-und-alle-eintraege-ausgeben.html)

Piro 18. Jan 2009 15:59

Datenbank: MS SQL 2005 Express • Zugriff über: ADO

SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Schönen guten Tag,

ich versuche 2 Tabellen miteinander zu vereinen. Die 1. Tabelle enthält die Computernamen und die 2 Tabelle enthält die Hotfixes, die auf den jeweiligen Rechnern installiert ist. SID entspricht der ID des Rechners.

Tabelle 1:
SQL-Code:
ID  Name
-------------
1    Rechner1
2    Rechner2
3    Rechner3
4    Rechner4
5    Rechner5
Tabelle 2:
SQL-Code:
ID  Hotfix    SID
-------------------
1    KB123456    1
2    KB123456    3
3    KB123456    5
Jetzt möchte ich, dass alle Rechner aus der 1. Tabelle angezeigt werden und wenn in der 2. Tabelle ein Hotfix für den jeweiligen Rechner da ist, dieser auch angezeigt wird. Falls nicht soll der Rechner trotzdem angezeigt werden.

Ausgabe:
SQL-Code:
System      Hotfix
-------------------
Rechner1     KB123456
Rechner2     
Rechner3     KB123456
Rechner4     
Rechner5     KB123456
Ich habe mit Inner JOIN und GROUP BY herum probiert aber leider ohne Erfolg.
Ich hoffe auf eure Erfahrung und euer Wissen und einer kann mir die Select-Anweisung sagen, um die gewünschte Ausgabe zur erhalten.

Vielen Dank im voraus.

Sven

mkinzler 18. Jan 2009 16:03

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Mit einem INNER JOIN werden dir nur Einträge gezeigt, welche in beiden tabellen vorhanden sind. Hier hilft ein LEFT (OUTER) JOIN

omata 18. Jan 2009 16:03

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
SQL-Code:
SELECT *
FROM tabelle1 t1
LEFT JOIN tabelle t2
  ON t1.id = t2.sid

Piro 18. Jan 2009 16:40

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Vielen Dank für eure Antwort. Ich habe es jetzt versucht und bin auf das nächste Problem gestoßen.

Also die 1. Tabelle bleibt so wie sie ist. Die 2. Tabelle wird um ein paar mehr Hoffixes erweitert.
SQL-Code:
ID  Hotfix    SID
-------------------
1    KB111111    1
2    KB111111    3
3    KB111111    5
4    KB222222    2
5    KB222222    3
6    KB222222    5
7    KB333333    1
8    KB333333    3
9    KB333333    5
Nun verwende ich folgende SQL Anweisung:
SQL-Code:
SELECT    t1.name, t2.hotfix
FROM        Tabelle1 AS t1 LEFT OUTER JOIN
                      Tabelle2 AS t2 ON t1.id = t2.sid
WHERE    (t2.hotfix = 'KB222222')
Nun habe ich folgende Ausgabe:
SQL-Code:
System      Hotfix
---------------------
Rechner2     KB222222
Rechner3     KB222222
Rechner5     KB222222
Ich möchte aber wieder alle ausgeben lassen. Was muss ich noch ändern damit es so aussieht?
SQL-Code:
System      Hotfix
-------------------
Rechner1
Rechner2     KB222222
Rechner3     KB222222
Rechner4
Rechner5     KB222222

DeddyH 18. Jan 2009 16:44

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Nicht groß nachgedacht, aber müsste das nicht das gewünschte Ergebnis liefern?
SQL-Code:
SELECT    t1.name, t2.hotfix
FROM        Tabelle1 AS t1 LEFT OUTER JOIN
                      Tabelle2 AS t2 ON t1.id = t2.sid
WHERE    (t2.hotfix = 'KB222222') or (t2.hotfix IS NULL)

omata 18. Jan 2009 16:45

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
SQL-Code:
SELECT t1.name, t2.hotfix
FROM tabelle1 t1 
LEFT JOIN tabelle2 t2 
  ON    t1.id = t2.sid
     AND t2.hotfix = 'KB222222'

DeddyH 18. Jan 2009 16:49

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Stimmt, in der Join-Bedingung ist das sinnvoller :oops:

Piro 18. Jan 2009 16:56

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
 
Genial. Danke euch.

Ich hoffe, ich bin irgendwann auch mal so fit wie ihr.

Danke nochmal.

Gruß, Sven


Alle Zeitangaben in WEZ +1. Es ist jetzt 07:20 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