Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst 2 SQL Abfragen kombinieren

Mitglied: flash-gordon

flash-gordon (Level 1) - Jetzt verbinden

07.11.2006, aktualisiert 09.11.2006, 7251 Aufrufe, 10 Kommentare

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
Mitglied: Biber
07.11.2006 um 21:17 Uhr
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äß:
01.
select distinct 
02.
COADR as "Wic_adress_complement",  
03.
ATSTATUS as "Wic_manager",  
04.
VOLLHGB as"Wic_marital_status",  
05.
ZIMMER as "WIC_uid",  
06.
BETRST as "Wic_etablishment",  
07.
PNR as "Wic_hrid",  
08.
NANAME as "Wic_name",  
09.
VORNAME as "Wic_firstname",  
10.
ORT as "Wic_town",  
11.
PLZ as "Wic_post_code",  
12.
STRASSE as "Wic_street", 
13.
PST_AB as "Wic_rights_beginning",  
14.
PST_BIS as "Wic_rights_end",  
15.
GRUPPE as "Wic_hrid_manager"  
16.
from L2001.PGRDAT PGR 
17.
 
18.
where PGR.PNR In Select 
19.
20.
SELECT PNR 
21.
FROM L2001.VERTRAG (NOLOCK) 
22.
WHERE ((VERENDE > Getdate() or VERENDE Is Null)) 
23.
AND VER_BIS = '2099-01-31 00:00:00.000' 
24.
)
[wenn es denn mehrere PNRn in der Vertragsdatei gibt, was ich Euch natürlich wünsche.]

Gruß
Biber
Bitte warten ..
Mitglied: flash-gordon
07.11.2006 um 21:26 Uhr
Hallo,

erstmal vielen Dank für die rasche Antwort.

Es handelt sich hier um einen MSSQL 2000 Server der auf einem W2003 OS läuft.

Deine query liefert folgende Ergebnis:

Server: Msg 156, Level 15, State 1, Line 18
Incorrect syntax near the keyword 'Select'.


Aber warum nur??? Schaut doch alles plausibel aus!
Bitte warten ..
Mitglied: Biber
07.11.2006 um 21:39 Uhr
uups... könnte ein "SELECT" zuviel sein... das nach dem "IN ".

Probier bitte mal
...
where PGR.PNR In (
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
Bitte warten ..
Mitglied: flash-gordon
07.11.2006 um 21:54 Uhr
Hey.....das klappt schonmal.

Allerdings liefert mir das Ergebnis nun 2674 Zeilen, obwohl es laut der Prüfung durch:

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'


nur 495 seien dürften.

Deine Query liefert demnach Duplikate im Feld PNR aus, die nicht durch die Prüfung gefiltert werden.

Ich versteh echt gar nix mehr. @Biber: machst du sowas hauptberuflich?
Bitte warten ..
Mitglied: Biber
07.11.2006 um 22:15 Uhr
Na dann halt anders...
01.
select distinct 
02.
COADR as "Wic_adress_complement",  
03.
ATSTATUS as "Wic_manager",  
04.
VOLLHGB as"Wic_marital_status",  
05.
ZIMMER as "WIC_uid",  
06.
BETRST as "Wic_etablishment",  
07.
PNR as "Wic_hrid",  
08.
NANAME as "Wic_name",  
09.
VORNAME as "Wic_firstname",  
10.
ORT as "Wic_town",  
11.
PLZ as "Wic_post_code",  
12.
STRASSE as "Wic_street", 
13.
PST_AB as "Wic_rights_beginning",  
14.
PST_BIS as "Wic_rights_end",  
15.
GRUPPE as "Wic_hrid_manager"  
16.
from L2001.PGRDAT PGR  
17.
Inner Join (SELECT PNR 
18.
FROM L2001.VERTRAG (NOLOCK) 
19.
WHERE ((VERENDE > Getdate() or VERENDE Is Null)) 
20.
AND VER_BIS = '2099-01-31 00:00:00.000' 
21.
) 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:
01.
select distinct 
02.
COADR as "Wic_adress_complement",  
03.
ATSTATUS as "Wic_manager",  
04.
VOLLHGB as"Wic_marital_status",  
05.
ZIMMER as "WIC_uid",  
06.
BETRST as "Wic_etablishment",  
07.
PNR as "Wic_hrid",  
08.
NANAME as "Wic_name",  
09.
VORNAME as "Wic_firstname",  
10.
ORT as "Wic_town",  
11.
PLZ as "Wic_post_code",  
12.
STRASSE as "Wic_street", 
13.
PST_AB as "Wic_rights_beginning",  
14.
PST_BIS as "Wic_rights_end",  
15.
GRUPPE as "Wic_hrid_manager"  
16.
from L2001.PGRDAT PGR,  L2001.VERTRAG (NOLOCK) Vertrag 
17.
Where PGR.PNR = Vertrag.PNR 
18.
And 
19.
 (Vertrag.VERENDE > Getdate() or Vertrag.VERENDE Is Null) 
20.
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
Bitte warten ..
Mitglied: flash-gordon
07.11.2006 um 22:31 Uhr
Ich dreh durch. Wenn ich das auch nur so könnte.

Hiermit :

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'


liefert er jetzt das:



Server: Msg 170, Level 15, State 1, Line 16
Line 16: Incorrect syntax near 'Vertrag'.



Wenn du evtl nochmal schauen könntest?!
Bitte warten ..
Mitglied: Biber
08.11.2006 um 09:11 Uhr
Hmm, flash-gordon,

habe leider keine M$-SQLServer zum Testen hier... lass mal bitte das "(nolock)" unten raus, mehr Vermutugen habe ich im Moment nicht...

Das heißt, jetzt wo ich draufgucke.... lass doch mal oben erstmal die "distinct"-Klausel weg.

Und dann schauen wir weiter.

Gruß
Biber
Bitte warten ..
Mitglied: flash-gordon
08.11.2006 um 09:30 Uhr
Dann bekomm ich ein:

Server: Msg 209, Level 16, State 1, Line 1
Ambiguous column name 'PNR'.
Bitte warten ..
Mitglied: Biber
08.11.2006 um 09:40 Uhr
Okay...das versteh ich.

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]
Bitte warten ..
Mitglied: MadMax
08.11.2006 um 09:44 Uhr
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
Bitte warten ..
Ähnliche Inhalte
Datenbanken
2 SQL Abfragen verbinden
Frage von cuxminiDatenbanken

Hallo Leute, ich habe mal das Problem, dass ich 2 Abfragen benötige um zum Ergebniss zu kommen. Ich hätte ...

Datenbanken

SQL-Dateien sortieren, kombinieren und filtern

gelöst Frage von derapfelsaftDatenbanken6 Kommentare

Hallo zusammen, ich habe folgende Problem: SQL Datei #1 hat die Spaltennamen: ID; Name; Phone; Funktion; Adresse SQL Datei ...

Datenbanken

Schleifen in SQL-Abfrage bei 2 Tabellen

gelöst Frage von AximandDatenbanken2 Kommentare

Hallo, ich hab mal wieder als totaler SQL-Anfänger ein Problemchen bei dem ich mir die Haare raufe. Ich habe ...

PHP

Abfrage SQL

gelöst Frage von dudeldoedelPHP3 Kommentare

Hallo zusammen, kann man das in einer SQL Abfrage erreichen ??? Feldwert lautet: {"565":{"textinput":{"comment":"1400"}}} als Ergebnis soll ausgelesen werden ...

Neue Wissensbeiträge
Sonstige Systeme
Es war einmal ein BeOS - Wer erinnert sich noch?
Information von BassFishFox vor 1 TagSonstige Systeme5 Kommentare

Hallo, Bin gerade ueber Haiku gestolpert, von dessen Existenz als "Nachfolger des BeOS" ich wusste nur mich nie wirklich ...

Datenschutz

Microsoft und DSGVO - ob das wohl jemals klappt (Probleme beim Datenabfluss für Office Pro Plus)?

Tipp von VGem-e vor 1 TagDatenschutz3 Kommentare

Servus Kollegen, siehe Aber wer setzt schon MS Office Pro Plus ein? Wie dann der Stand beim "normalen" MS ...

Windows 10

Macht Windows 10.1809 Probleme mit gemappten Netzlaufwerken (betrifft wohl insbes. AMD-Hardware und Trend Micro AV-Produkte)?

Tipp von VGem-e vor 1 TagWindows 103 Kommentare

Moin Kollegen, grad dazu gefunden und Hatten wir dies nicht bei früheren W10-Upgrades ebenfalls? Da bleibt nur, das Upgrade ...

Humor (lol)

Das neue Miniatur Wunderland OFFICIAL VIDEO - worlds largest model railway - railroad

Information von StefanKittel vor 2 TagenHumor (lol)2 Kommentare

Hallo, wer noch nie im Miniatur Wunderland war, sollte es dringend mal nachholen. Es gibt eine neues Video. Viele ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
Gäste-WLAN durch DD-WRT AP nach einem MikroTik Routerboard
Frage von NukolarLAN, WAN, Wireless16 Kommentare

Hallo, wie der Titel schon sagt möchte ich gerne ein Gäste-WLAN innerhalb eines bestehenden LANs einrichten. Dass die Gäste ...

DSL, VDSL
DSL Monitoring Tool - Quick and dirty?
Frage von george44DSL, VDSL15 Kommentare

Liebe Gemeinde, ich suche ein einfaches und vor allem schnell zu installierendes Monitoring-Tool zur kontinuierlichen Dokumentation (nur) der Internetanbindung. ...

Exchange Server
Outlook findet Postfach nicht
Frage von MaximaxExchange Server11 Kommentare

Hallo, und zwar haben wir auf der Arbeit ein kleines (großes) Exchange 2016 Problem. Exchange meldete gestern, dass die ...

Informationsdienste
Probleme auf dem Server
Frage von LangeLangeInformationsdienste9 Kommentare

Hallo zusammen, ich betreibe die Seite Keine Werbelinks. In der Analyse stellen wir fest, dass die Ladezeit in der ...