![]() |
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:
Tabelle 2:
ID Name
------------- 1 Rechner1 2 Rechner2 3 Rechner3 4 Rechner4 5 Rechner5
SQL-Code:
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.
ID Hotfix SID
------------------- 1 KB123456 1 2 KB123456 3 3 KB123456 5 Ausgabe:
SQL-Code:
Ich habe mit Inner JOIN und GROUP BY herum probiert aber leider ohne Erfolg.
System Hotfix
------------------- Rechner1 KB123456 Rechner2 Rechner3 KB123456 Rechner4 Rechner5 KB123456 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 |
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
|
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 |
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:
Nun verwende ich folgende SQL Anweisung:
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
SQL-Code:
Nun habe ich folgende Ausgabe:
SELECT t1.name, t2.hotfix
FROM Tabelle1 AS t1 LEFT OUTER JOIN Tabelle2 AS t2 ON t1.id = t2.sid WHERE (t2.hotfix = 'KB222222')
SQL-Code:
Ich möchte aber wieder alle ausgeben lassen. Was muss ich noch ändern damit es so aussieht?
System Hotfix
--------------------- Rechner2 KB222222 Rechner3 KB222222 Rechner5 KB222222
SQL-Code:
System Hotfix
------------------- Rechner1 Rechner2 KB222222 Rechner3 KB222222 Rechner4 Rechner5 KB222222 |
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) |
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' |
Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben
Stimmt, in der Join-Bedingung ist das sinnvoller :oops:
|
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 04:23 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