2 SQL Abfragen kombinieren
Hallo,
ich bin der Meinung schon alles, in meinem Wissenspektrum befindliche, probiert zu haben. Aber ich komme einfach nicht weiter. Wahrscheinlich ein typischer Fall von Denkblockade. Auch die Forensuche, für 2 Abfragen kombinieren, fruchtete nicht.
Also hier mein Anliegen:
Ich möchte aus einer DB wie folgt extrahieren (klappt so auch):
select distinct
COADR as "Wic_adress_complement",
ATSTATUS as "Wic_manager",
VOLLHGB as"Wic_marital_status",
ZIMMER as "WIC_uid",
BETRST as "Wic_etablishment",
PNR as "Wic_hrid",
NANAME as "Wic_name",
VORNAME as "Wic_firstname",
ORT as "Wic_town",
PLZ as "Wic_post_code",
STRASSE as "Wic_street",
PST_AB as "Wic_rights_beginning",
PST_BIS as "Wic_rights_end",
GRUPPE as "Wic_hrid_manager"
from L2001.PGRDAT
In der gleichen Abfrage möchte ich aber noch eine Prüfung integrieren (einzeln klappt diese Abfrage ebenfalls):
SELECT PNR as "Wic_hrid"
FROM L2001.VERTRAG (NOLOCK)
WHERE ((VERENDE > Getdate() or VERENDE Is Null))
AND VER_BIS = '2099-01-31 00:00:00.000'
Der Schlüssel zum Erfolg scheint also PNR as "Wic_hrid" zu sein.
Jedoch bekomm ich das beides nicht in eine SQL query gepackt. Kann mir hier bitte jemand helfen? Auch wenn ich Gefahr laufe, auf schallendes Gelächter über SQL Newbies zu stoßen!
Vielen vielen Dank dennoch im Vorraus.
O G
ich bin der Meinung schon alles, in meinem Wissenspektrum befindliche, probiert zu haben. Aber ich komme einfach nicht weiter. Wahrscheinlich ein typischer Fall von Denkblockade. Auch die Forensuche, für 2 Abfragen kombinieren, fruchtete nicht.
Also hier mein Anliegen:
Ich möchte aus einer DB wie folgt extrahieren (klappt so auch):
select distinct
COADR as "Wic_adress_complement",
ATSTATUS as "Wic_manager",
VOLLHGB as"Wic_marital_status",
ZIMMER as "WIC_uid",
BETRST as "Wic_etablishment",
PNR as "Wic_hrid",
NANAME as "Wic_name",
VORNAME as "Wic_firstname",
ORT as "Wic_town",
PLZ as "Wic_post_code",
STRASSE as "Wic_street",
PST_AB as "Wic_rights_beginning",
PST_BIS as "Wic_rights_end",
GRUPPE as "Wic_hrid_manager"
from L2001.PGRDAT
In der gleichen Abfrage möchte ich aber noch eine Prüfung integrieren (einzeln klappt diese Abfrage ebenfalls):
SELECT PNR as "Wic_hrid"
FROM L2001.VERTRAG (NOLOCK)
WHERE ((VERENDE > Getdate() or VERENDE Is Null))
AND VER_BIS = '2099-01-31 00:00:00.000'
Der Schlüssel zum Erfolg scheint also PNR as "Wic_hrid" zu sein.
Jedoch bekomm ich das beides nicht in eine SQL query gepackt. Kann mir hier bitte jemand helfen? Auch wenn ich Gefahr laufe, auf schallendes Gelächter über SQL Newbies zu stoßen!
Vielen vielen Dank dennoch im Vorraus.
O G
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 43935
Url: https://administrator.de/forum/2-sql-abfragen-kombinieren-43935.html
Ausgedruckt am: 24.01.2025 um 19:01 Uhr
10 Kommentare
Neuester Kommentar
Moin flash-gordon,
willkommen im Forum.
Erste Bitte: wenn es um SQL geht, schreib bitte dazu, auf welchem Blech das läuft...
denn SQL ist ebenso standardisiert wie die PET-Flaschen, die jeder Getränkeautomat natürlich problemlos erkennt...
Aus meiner Erfahrung gibt es aber schon winzigkleineganzganzniedliche Unterschiede zwischen MySQl, Oracle, DB2 und Nachwuchsartisten wie M$-Access...
However, sinngemäß:
[wenn es denn mehrere PNRn in der Vertragsdatei gibt, was ich Euch natürlich wünsche.]
Gruß
Biber
willkommen im Forum.
Erste Bitte: wenn es um SQL geht, schreib bitte dazu, auf welchem Blech das läuft...
denn SQL ist ebenso standardisiert wie die PET-Flaschen, die jeder Getränkeautomat natürlich problemlos erkennt...
Aus meiner Erfahrung gibt es aber schon winzigkleineganzganzniedliche Unterschiede zwischen MySQl, Oracle, DB2 und Nachwuchsartisten wie M$-Access...
However, sinngemäß:
select distinct
COADR as "Wic_adress_complement",
ATSTATUS as "Wic_manager",
VOLLHGB as"Wic_marital_status",
ZIMMER as "WIC_uid",
BETRST as "Wic_etablishment",
PNR as "Wic_hrid",
NANAME as "Wic_name",
VORNAME as "Wic_firstname",
ORT as "Wic_town",
PLZ as "Wic_post_code",
STRASSE as "Wic_street",
PST_AB as "Wic_rights_beginning",
PST_BIS as "Wic_rights_end",
GRUPPE as "Wic_hrid_manager"
from L2001.PGRDAT PGR
where PGR.PNR In Select
(
SELECT PNR
FROM L2001.VERTRAG (NOLOCK)
WHERE ((VERENDE > Getdate() or VERENDE Is Null))
AND VER_BIS = '2099-01-31 00:00:00.000'
)
Gruß
Biber
Na dann halt anders...
Wie viele sind es jetzt?
Wenn es jetzt mit 495 Sätzen passt, dann nehmen wir den Inner Join wieder raus und
ersetzen das durch:
Was heißt schon hauptberuflich... ich denke, meine Berufung sind Algorithmen...
Und Kochen natürlich...
Gruß
Biber
select distinct
COADR as "Wic_adress_complement",
ATSTATUS as "Wic_manager",
VOLLHGB as"Wic_marital_status",
ZIMMER as "WIC_uid",
BETRST as "Wic_etablishment",
PNR as "Wic_hrid",
NANAME as "Wic_name",
VORNAME as "Wic_firstname",
ORT as "Wic_town",
PLZ as "Wic_post_code",
STRASSE as "Wic_street",
PST_AB as "Wic_rights_beginning",
PST_BIS as "Wic_rights_end",
GRUPPE as "Wic_hrid_manager"
from L2001.PGRDAT PGR
Inner Join (SELECT PNR
FROM L2001.VERTRAG (NOLOCK)
WHERE ((VERENDE > Getdate() or VERENDE Is Null))
AND VER_BIS = '2099-01-31 00:00:00.000'
) Vertrag on PGR.PNR=Vertrag.PNR
Wie viele sind es jetzt?
Wenn es jetzt mit 495 Sätzen passt, dann nehmen wir den Inner Join wieder raus und
ersetzen das durch:
select distinct
COADR as "Wic_adress_complement",
ATSTATUS as "Wic_manager",
VOLLHGB as"Wic_marital_status",
ZIMMER as "WIC_uid",
BETRST as "Wic_etablishment",
PNR as "Wic_hrid",
NANAME as "Wic_name",
VORNAME as "Wic_firstname",
ORT as "Wic_town",
PLZ as "Wic_post_code",
STRASSE as "Wic_street",
PST_AB as "Wic_rights_beginning",
PST_BIS as "Wic_rights_end",
GRUPPE as "Wic_hrid_manager"
from L2001.PGRDAT PGR, L2001.VERTRAG (NOLOCK) Vertrag
Where PGR.PNR = Vertrag.PNR
And
(Vertrag.VERENDE > Getdate() or Vertrag.VERENDE Is Null)
AND Vertrag.VER_BIS = '2099-01-31 00:00:00.000'
Was heißt schon hauptberuflich... ich denke, meine Berufung sind Algorithmen...
Und Kochen natürlich...
Gruß
Biber
Okay...das versteh ich.
Bitte statt
Alle anderen Feldnamen in der Tabelle "L2001.PGRDAT" scheinen ja nicht in der "Vertrag"stabelle vorzukommen.
Aber bei PNR kann er sich natürlich nicht entscheiden, welches er nehmen soll.
Vielleicht sollte ich erstmal einen Kaffee trinken zum Wachwerden *grübel*
[Edit] Sorry, die Zeile unter "Jetzt ganz ordentlich.." war nicht sichtbar. (Falsch formatiert von mir).
[/Edit]
Bitte statt
PNR as "Wic_hrid",
jetzt ganz ordentlich:PGR.PNR as "Wic_hrid",
Alle anderen Feldnamen in der Tabelle "L2001.PGRDAT" scheinen ja nicht in der "Vertrag"stabelle vorzukommen.
Aber bei PNR kann er sich natürlich nicht entscheiden, welches er nehmen soll.
Vielleicht sollte ich erstmal einen Kaffee trinken zum Wachwerden *grübel*
[Edit] Sorry, die Zeile unter "Jetzt ganz ordentlich.." war nicht sichtbar. (Falsch formatiert von mir).
[/Edit]
Hallo,
wenn ich grade mal Eure traute Zweisamkeit unterbrechen darf:
Flash, daß die Abfrage auf PGRDAT 2674 Datensätze zurückgibt, während die auf VERTRAG nur 495 liefert, ist völlig in Ordnung. In PGRDAT können zu einer PNR ja mehrere Datensätze existieren. Wenn Du 500 Datensätze in VERTRAG hast und jede PNR existiert in PGRDAT fünf mal, dann hast Du folglich insgesamt 2.500 Datensätze, die da gelesen werden. Das DISTINCT bezieht sich ja nicht nur auf die PNR, sondern auf alle Felder.
Wenn das Ergebnis nicht das ist, was Du erwartest, müßtest Du mehr Infos liefern, was da rauskommen sollte, aber die erste Abfrage von Biber war (bis auf das überflüssige SELECT) völlig richtig in Hinsicht auf die ursprüngliche Frage von Dir.
Gruß, Mad Max
wenn ich grade mal Eure traute Zweisamkeit unterbrechen darf:
Flash, daß die Abfrage auf PGRDAT 2674 Datensätze zurückgibt, während die auf VERTRAG nur 495 liefert, ist völlig in Ordnung. In PGRDAT können zu einer PNR ja mehrere Datensätze existieren. Wenn Du 500 Datensätze in VERTRAG hast und jede PNR existiert in PGRDAT fünf mal, dann hast Du folglich insgesamt 2.500 Datensätze, die da gelesen werden. Das DISTINCT bezieht sich ja nicht nur auf die PNR, sondern auf alle Felder.
Wenn das Ergebnis nicht das ist, was Du erwartest, müßtest Du mehr Infos liefern, was da rauskommen sollte, aber die erste Abfrage von Biber war (bis auf das überflüssige SELECT) völlig richtig in Hinsicht auf die ursprüngliche Frage von Dir.
Gruß, Mad Max