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

Zeilenverdopplung bei 1:N Join verhindern

Frage Entwicklung Datenbanken

Mitglied: wiesi200

wiesi200 (Level 5) - Jetzt verbinden

18.04.2014, aktualisiert 12:45 Uhr, 2518 Aufrufe, 5 Kommentare

Hallo,

ich habe ein kleines Problem mit einer SQL Abfrage auch unser ERP System.
Grundsätzlich mal handelt es sich um einen MS SQL Server und eine Abfrage über ein paar Tabellen.

An einer Stelle habe ich ein Problem

Und zwar mache ich aktuell einen Left Join wobei hier eine 1:N Beziehung vorhanden ist.
Dadurch wird in der Ausgabe die Zeile aus der linken Tabelle natürlich um den Faktor N vervielfältigt.

Ich bräuchte sie jedoch nur 1x bzw. möchte eigentlich nur wissen ob es in der rechten Tabelle entsprechende Datensätze gibt oder nicht.
Und leider hab ich zu selten direkt mit SQL Abfragen zu tun um das Problem alleine zu lösen.

Vielleicht kann mir ja jemand helfen.

schon mal Danke

Mitglied: colinardo
18.04.2014, aktualisiert um 12:06 Uhr
Hi wiesi,
könntest du mit count() so machen:
01.
SELECT Count(*) AS Anzahl 
02.
FROM TabelleA 
03.
LEFT JOIN TabelleB ON TabelleA.ID = TabelleB.ID 
04.
WHERE TabelleB.ID=15
das gibt dir nur eine Spalte(Name: "Anzahl") und eine Zeile mit der Anzahl der gefundenen Datensätze aus.

Grüße Uwe
Bitte warten ..
Mitglied: wiesi200
18.04.2014, aktualisiert um 12:21 Uhr
Erst mal danke aber bringt mich noch nicht weiter

vereinfacht ausgedrückt

Tabelle1
FA-NrRef-Nr
FA1401-00011
FA1401-00022
FA1401-00033

Tabelle2
AB-NrRef-Nr
AB1401-00011
AB1401-00023
AB1401-00033

Wunschausgabe
FA-NRAB-Vorhanden
FA1401-0001Ja
FA1401-0002Nein
FA1401-0003Ja

Wobei was jetzt genau in der Spalte AB-Vorhanden drinnen steht spielt für mich nicht die Rolle

Das währ noch die original Abfrage

01.
SELECT TOP 20 porl.[Prod_ Order No_],porl.[Previous Operation No_],porl.[Routing No_],item.[Description],porl.[Input Quantity],po.[Drawing No_],job.[Sell-to Customer Name],porl.[Extended Routing Status],porl2.Transported,porl3.[Work Center Group Code] 
02.
FROM [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl  
03.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Item] item on (porl.[Routing No_] = item.[No_])  
04.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Production Order] po on (po.[No_] = porl.[Prod_ Order No_]) 
05.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job] job on (po.[Shortcut Dimension 2 Code] = job.[No_]) 
06.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl2 on (porl.[Prod_ Order No_] = porl2.[Prod_ Order No_] and porl.[Previous Operation No_] = porl2.[Operation No_]) 
07.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl3 on (porl.[Prod_ Order No_] = porl3.[Prod_ Order No_] and porl.[Next Operation No_] = porl3.[Operation No_]) 
08.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job Relation] JobRel1 on ([JobRel1].[Source Type] = '5406' and [JobRel1].[Source ID] = porl.[Prod_ Order No_]) 
09.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job Relation] JobRel2 on (JobRel1.[Job Structure Entry No_] = JobRel2.[Job Structure Entry No_] and JobRel2.[Source Type] = '37') 
10.
where porl.[Work Center Group Code] = 'QS' and porl.[Status] = 3 and porl.[Extended Routing Status] < 6  
11.
and EXISTS (Select * From  [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] privporl  
12.
where privporl.[Prod_ Order No_] = porl.[Prod_ Order No_] and privporl.[Operation No_] = porl.[Previous Operation No_] and privporl.[Extended Routing Status] = 6) 
13.
ORDER BY porl.[Starting Date-Time]
Bitte warten ..
Mitglied: gemini
LÖSUNG 18.04.2014, aktualisiert um 12:45 Uhr
Hallo Wiesi,

evtl. hilft dir auch Distinct
01.
SELECT DISTINCT irgendwas FROM tabelle LEFT JOIN ...
Gruß,
gemini
Bitte warten ..
Mitglied: colinardo
LÖSUNG 18.04.2014, aktualisiert um 12:45 Uhr
das bekommst du so Gruppiert
01.
SELECT Tabelle1.FA-Nr, Count(Tabelle2.Ref-Nr) AS AB-Anzahl 
02.
FROM Tabelle1 
03.
LEFT JOIN Tabelle2 ON Tabelle1.Ref-Nr = Tabelle2.Ref-Nr 
04.
Group by Tabelle1.FA-Nr
Grüße Uwe
Bitte warten ..
Mitglied: wiesi200
18.04.2014, aktualisiert um 12:53 Uhr
Also noch mal Danke euch beiden,

Group und Distinct hab ich zwar schon probiert, hat aber nicht gleich funktioniert.
Jetzt funktioniert es aber
Hat daran gelegen das ich bei der original Abfrage die AB Nummer ausgegeben habe, da diese immer ne andere war konnte er die nicht gruppieren.

01.
SELECT TOP 20 porl.[Prod_ Order No_],porl.[Previous Operation No_],porl.[Routing No_],item.[Description],porl.[Input Quantity],po.[Drawing No_],job.[Sell-to Customer Name],porl.[Extended Routing Status],porl2.Transported,porl3.[Work Center Group Code], porl.[Starting Date-Time], COUNT(JobRel2.[Job Structure Entry No_]) as [AB Anzahl] 
02.
FROM [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl  
03.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Item] item on (porl.[Routing No_] = item.[No_])  
04.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Production Order] po on (po.[No_] = porl.[Prod_ Order No_]) 
05.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job] job on (po.[Shortcut Dimension 2 Code] = job.[No_]) 
06.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl2 on (porl.[Prod_ Order No_] = porl2.[Prod_ Order No_] and porl.[Previous Operation No_] = porl2.[Operation No_]) 
07.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] porl3 on (porl.[Prod_ Order No_] = porl3.[Prod_ Order No_] and porl.[Next Operation No_] = porl3.[Operation No_]) 
08.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job Relation] JobRel1 on ([JobRel1].[Source Type] = '5406' and [JobRel1].[Source ID] = porl.[Prod_ Order No_]) 
09.
left join [Dynamics-NAV].[dbo].[Resch Maschinenbau$Job Relation] JobRel2 on (JobRel1.[Job Structure Entry No_] = JobRel2.[Job Structure Entry No_] and JobRel2.[Source Type] = '37') 
10.
where porl.[Work Center Group Code] = 'QS' and porl.[Status] = 3 and porl.[Extended Routing Status] < 6  
11.
and EXISTS (Select * From  [Dynamics-NAV].[dbo].[Resch Maschinenbau$Prod_ Order Routing Line] privporl  
12.
where privporl.[Prod_ Order No_] = porl.[Prod_ Order No_] and privporl.[Operation No_] = porl.[Previous Operation No_] and privporl.[Extended Routing Status] = 6) 
13.
GROUP BY porl.[Prod_ Order No_],porl.[Previous Operation No_],porl.[Routing No_],item.[Description],porl.[Input Quantity],po.[Drawing No_],job.[Sell-to Customer Name],porl.[Extended Routing Status],porl2.Transported,porl3.[Work Center Group Code], porl.[Starting Date-Time] 
14.
ORDER BY porl.[Starting Date-Time]
Bitte warten ..
Ähnliche Inhalte
Exchange Server
1 von n-Benutzer kann keine E-Mails verschicken
Frage von malikaExchange Server3 Kommentare

Hallo zusammen, ich habe einen Benutzer, der plötzlich E-Mails weder über Webinterface (OWA) noch über Outlook verschicken kann. Die ...

Datenbanken
MySQL - Join
Frage von ThoomaasDatenbanken4 Kommentare

Hallo alle zusammen! Ich habe zwei Tabellen in meiner Datenbank. Die eine beinhaltet Teams und einen Code zum Team ...

E-Mail
Spam verhindern über 1.Received IP Adresse
Frage von greatmgmE-Mail10 Kommentare

Guten Morgen zusammen, um der meisten Spam/Virenschleudern Herr zu werden, folgende Überlegung: Kann ein Spamfilter (beim Provider, in diesem ...

Datenbanken
SQL LEFT JOIN in Spalten
gelöst Frage von StfnCstrDatenbanken5 Kommentare

Hallo, ich sehe mal wieder den Wald vor lauter Bäumen nicht. Ich habe 2 Tabellen Tabelle 1: PK, Vorname, ...

Neue Wissensbeiträge
Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 50 MinutenInternet2 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 4 StundenDSL, VDSL1 Kommentar

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Windows 10

Microsoft bestätigt DMA-Policy-Problem in Win10 v1709

Information von DerWoWusste vor 4 StundenWindows 10

Wer sein Gerät mit der DMA-Policy absichert, bekommt evtl. Hardwareprobleme in v1709 von Win10. Warum? Weil v1709 endlich "richtig" ...

Verschlüsselung & Zertifikate

Die Hölle friert ein weiteres Stück zu: Microsoft integriert OpenSSH in Windows

Information von ticuta1 vor 8 StundenVerschlüsselung & Zertifikate

Interessant Die Hölle friert ein weiteres Stück zu: Microsoft integriert OpenSSH in Windows SSH-Kommando in CMD.exe und PowerShell

Heiß diskutierte Inhalte
Windows Server
RODC kann nicht aus Domäne entfernt werden
Frage von NilsvLehnWindows Server19 Kommentare

HAllo, ich arbeite in einem Universitätsnetzwerk mit 3 Standorten. Die Standorte haben alle ein ESXi Cluster und auf diesen ...

Hardware
Kein Bild mit nur einer bestimmten Grafikkarten - Mainboard Konfiguration
gelöst Frage von bestelittHardware18 Kommentare

Hallo zusammen, ich hatte schon einmal eine ähnliche Frage gestellt. Damals hatte ich genau das gleiche Problem. Allerdings lies ...

Netzwerkmanagement
Mehrere Netzwerkadapter in einem PC zu einem Switch zusammenfügen
Frage von prodriveNetzwerkmanagement18 Kommentare

Hallo zusammen Vorweg, ich konnte schon einige IT-Probleme mit Hilfe dieses Forums lösen. Wirklich klasse hier! Doch für das ...

Hardware
Links klick bei Maus funktioniert nicht
gelöst Frage von Pablu23Hardware16 Kommentare

Hallo erstmal. Ich habe ein Problem mit meiner relativ alten maus jedoch denke ich nicht das es an der ...