AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL + 2 Tabellen vereinen und alle Einträge ausgeben
Thema durchsuchen
Ansicht
Themen-Optionen

SQL + 2 Tabellen vereinen und alle Einträge ausgeben

Ein Thema von Piro · begonnen am 18. Jan 2009 · letzter Beitrag vom 18. Jan 2009
Antwort Antwort
Benutzerbild von Piro
Piro

Registriert seit: 14. Jul 2003
Ort: Flintbek
810 Beiträge
 
Delphi XE2 Professional
 
#1

SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 15:59
Datenbank: MS SQL 2005 Express • Zugriff über: ADO
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
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:03
Mit einem INNER JOIN werden dir nur Einträge gezeigt, welche in beiden tabellen vorhanden sind. Hier hilft ein LEFT (OUTER) JOIN
Markus Kinzler
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:03
SQL-Code:
SELECT *
FROM tabelle1 t1
LEFT JOIN tabelle t2
  ON t1.id = t2.sid
  Mit Zitat antworten Zitat
Benutzerbild von Piro
Piro

Registriert seit: 14. Jul 2003
Ort: Flintbek
810 Beiträge
 
Delphi XE2 Professional
 
#4

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:40
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
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.546 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:44
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)
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
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:45
SQL-Code:
SELECT t1.name, t2.hotfix
FROM tabelle1 t1
LEFT JOIN tabelle2 t2
  ON t1.id = t2.sid
     AND t2.hotfix = 'KB222222'
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.546 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:49
Stimmt, in der Join-Bedingung ist das sinnvoller
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
Benutzerbild von Piro
Piro

Registriert seit: 14. Jul 2003
Ort: Flintbek
810 Beiträge
 
Delphi XE2 Professional
 
#8

Re: SQL + 2 Tabellen vereinen und alle Einträge ausgeben

  Alt 18. Jan 2009, 16:56
Genial. Danke euch.

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

Danke nochmal.

Gruß, Sven
  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 17:51 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