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

SQL Left outer Join Problem

Frage Entwicklung Datenbanken

Mitglied: CouchCoach

CouchCoach (Level 1) - Jetzt verbinden

24.11.2005, aktualisiert 26.11.2005, 8938 Aufrufe, 5 Kommentare

Es werden nicht alle Inhalte der linken Tablle beim left outer join zurückgegeben

Tach NG, need education!!!

Habe in einer SQL (M$ SQL Server) Abfrage folgendes Problem.

Bei folgendem Join werden nicht alle Inhalte der linken Tabelle zurückgegeben.

select tblKonten.Konto,
tblKonten.Bezeichnung,
sum(viewAusgaben.KostenA) as KostA,
sum(viewAusgaben.KostenB) as KostB
from tblKonten
left outer join viewAusgaben
on tblKonten.Konto = viewAusgaben.Konto
group by tblKonten.Konto, tblKonten.Bezeichnung
order by tblKonten.Konto, tblKonten.Bezeichnung

soweit klappt alles!!! aber wenn ich noch eine Einschränkung auf den Zeitraum in der viewAusgaben machen werden nicht mehr alle Inhalte aus der linken Tabelle tblKonten zurückgegeben

where viewAusgaben.Monat >= 1 -- hier werden die Werte normalerweise per Variable an die procedure übergeben
and viewAusgaben.Monat <= 12

Weiß jemand wieso durch die where Einschränkung nicht mehr der komplette Inhalt aus der tblKonten (linke Tabelle) zurückgegeben wird?

Grüße und Danke für Lösungen und Lernhilfe

Kai
Mitglied: 16640
24.11.2005 um 09:32 Uhr
Hast Du Dir schon mal den Ablaufplan angeschaut?
Werden in der View auch schon Joins verwendet?

Gruß
dba
Bitte warten ..
Mitglied: CouchCoach
24.11.2005 um 10:11 Uhr
Ja in der View gibt es ebenfalls einen Join. Kurioser Weise mit den gleichen beiden Tabellen wie in der proc.
Allerdings muß ich das so machen da ich am Ende eine Ausgabe in der Form einer Kreuztabelle erhalte.
Vielleicht gibt es hierfür ja auch einen anderen Weg?!?

Den AP werde ich mir gleich noch einmal anschauen und werden dazu dann noch einmal posten.

Grüße Kai
Bitte warten ..
Mitglied: MadMax
26.11.2005 um 03:22 Uhr
Hallo Kai,

das liegt daran, daß die Auswertung des Zeitraums erst nach dem Outer Join erfolgt. Der Outer Join wird also korrekt ausgeführt, aber anschließend fliegen alle Datensätze raus, die das Monatskriterium nicht erfüllen. Hierzu zählen natürlich auch alle Konten, die gar keinen Datensatz in viewAusgaben haben, weil viewAusgaben.Monat in dem Fall nämlich NULL ist.

Abhilfe schafft man dadurch, daß die Einschränkung auf den Zeitraum in den Outer Join aufgenommen wird. Dann wird zunächst die Monatseinschränkung auf viewAusgaben ausgeführt und erst dann die übrigen Datensätze per Outer Join den Konten zugeordnet. Der passende SQL-Befehl lautet:

select tblKonten.Konto,
tblKonten.Bezeichnung,
sum(viewAusgaben.KostenA) as KostA,
sum(viewAusgaben.KostenB) as KostB
from tblKonten
left outer join viewAusgaben
on tblKonten.Konto = viewAusgaben.Konto
and (viewAusgaben.Monat >= 1 and viewAusgaben.Monat <= 12)
group by tblKonten.Konto, tblKonten.Bezeichnung
order by tblKonten.Konto, tblKonten.Bezeichnung

Gruß, Mad Max
Bitte warten ..
Mitglied: CouchCoach
26.11.2005 um 12:47 Uhr
Many Thanx MAD MAX,

ist ja eigentlich logisch, aber manchmal seh ich halt den Wald vor lauter Bäumen nicht mehr.
Viel beeindruckender finde ich jedoch deine posting Uhrzeit!!! Solche Mitarbeiter möchte ich auch bei mir haben, das nennt man Einsatzbereitschaft.

Grüße und danke nochmal

Kai
Bitte warten ..
Mitglied: MadMax
26.11.2005 um 18:22 Uhr
Bitteschön.

Jeder hat halt so seine Zeit, wahrscheinlich hätte ich um 9 Uhr das Problem auch nicht lösen können

Gruß, Mad Max
Bitte warten ..
Ähnliche Inhalte
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, ...

Datenbanken
SQL Abfrage Problem Time OUt
Frage von frankiecologneDatenbanken2 Kommentare

Hallo, kann mir jemand sagen was hier falsch ist? Bekomme ein timeOut SELECT fullname, contactid AS Kontaktid FROM FilteredContact ...

Datenbanken
SQL - JOIN zeigt mehrfaches an
Frage von MiStDatenbanken9 Kommentare

Guten Morgen, ich habe mich frisch mit dem Thema SQL "angefreundet". Jetzt habe ich aber irgendwie ein Problem. Und ...

Datenbanken
SQL - Mehrere Tabellen über JOINS verketten
Frage von GwahlersDatenbanken1 Kommentar

Aktuell habe ich das Problem dass die Ausgabe von meinen Erwartungen abweicht JOINS und Tabellen im Anhang Folgende Abfrage ...

Neue Wissensbeiträge
Batch & Shell

Open Object Rexx: Eine mittlerweile fast vergessene Skriptsprache aus dem Mainframebereich

Information von Penny.Cilin vor 12 StundenBatch & Shell8 Kommentare

Ich kann mich noch sehr gut an diese Skriptsprache erinnern und nutze diese auch heute ab und an noch. ...

Humor (lol)

"gimme gimme gimme": Automatischer Test stolpert über Easter Egg im man-Tool

Information von Penny.Cilin vor 14 StundenHumor (lol)6 Kommentare

Interessant, was man so alles als Easter Egg implementiert. Ist schon wieder Ostern? "gimme gimme gimme": Automatischer Test stolpert ...

MikroTik RouterOS

Mikrotik - Lets Encrypt Zertifikate mit MetaROUTER Instanz auf dem Router erzeugen

Anleitung von colinardo vor 1 TagMikroTik RouterOS8 Kommentare

Einleitung Folgende Anleitung ist aus der Lage heraus entstanden das ein Kunde auf seinem Mikrotik sein Hotspot Captive Portal ...

Sicherheit

Sicherheitslücke in HP-Druckern - Firmware-Updates stehen bereit

Information von BassFishFox vor 1 TagSicherheit1 Kommentar

Ein weiterer Grund, dass Drucker keinerlei Verbindung nach "auswaerts" haben sollen. Unter Verwendung spezieller Malware können Angreifer aus der ...

Heiß diskutierte Inhalte
Windows Server
RDP macht Server schneller???
Frage von JaniDJWindows Server17 Kommentare

Hallo Community, wir betrieben seit geraumer Zeit diverse virtuelle Maschinen und Server mit Windows Server 2012. Leider haben wir ...

Windows 10
Windows 10 dunkler Bildschirm nach Umfallen
Frage von AkcentWindows 1015 Kommentare

Hallo, habe hier einen Windows 10 Rechner der von einem User umgefallen wurde (Beine übers Knie, an den PC ...

Windows 10
Bitlocker nach Verschlüsselung nicht mehr aufrufbar!
gelöst Frage von alexlazaWindows 1013 Kommentare

Hallo, ich besitze ein HP ZBook 17 G4 mit einem Windows 10 Pro Betriebssystem. Bei diesem Problem handelt sich, ...

Batch & Shell
Neuste Datei via PowerShell kopieren
gelöst Frage von kaiuwe28Batch & Shell11 Kommentare

Hallo zusammen, ich hatte mir mit Hilfe der Suche im Forum einen kleinen Code von colinardo rausgesucht und versucht ...