AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Eingeschobener Join

Ein Thema von Win32.API · begonnen am 14. Feb 2012 · letzter Beitrag vom 15. Feb 2012
Antwort Antwort
Seite 2 von 2     12   
Win32.API

Registriert seit: 23. Mai 2005
312 Beiträge
 
#11

AW: Eingeschobener Join

  Alt 15. Feb 2012, 09:04
Ihr habt Recht, ich habe einen kleinen Tippfehler gemacht:

SQL-Code:
select * from A a
    left join B b
        (
            join C c on c.key = b.key
          --join C c on c.key = a.key
        )
    on b.key = a.key;
@Iwo Asnet: Danke für die Erklärung mit der Mengenlehre, mit der Explizit hingeschriebenen Klammer wird dies auch sofort deutlich.
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.733 Beiträge
 
Delphi 6 Enterprise
 
#12

AW: Eingeschobener Join

  Alt 15. Feb 2012, 09:17
Ist denn ein Join dasselbe wie ein Left Join?
Wenn nicht, wage ich mal zu behaupten, das die Ergebnismenge nicht gleich sein muss, wie bei der Version mit den zwei Left Joins, da die eingeschobene Variante evtl. weniger zurückliefert als nur B.

Kann aber auch sein, dass ich da gerade zusehr um die Ecke denke
Ralph
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

AW: Eingeschobener Join

  Alt 15. Feb 2012, 09:25
Ist denn ein Join dasselbe wie ein Left Join?
Nein, JOIN ist die verkürzte Syntax für INNER JOIN, LEFT JOIN die Kurzform von LEFT OUTER JOIN.
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

Geändert von DeddyH (15. Feb 2012 um 09:30 Uhr) Grund: Entscheidende Unterschiede hervorgehoben
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#14

AW: Eingeschobener Join

  Alt 15. Feb 2012, 09:27
Nein, es ist nicht das gleiche.

http://psoug.org/definition/JOIN.htm
http://psoug.org/reference/joins.html
Gruß, Jo
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.733 Beiträge
 
Delphi 6 Enterprise
 
#15

AW: Eingeschobener Join

  Alt 15. Feb 2012, 09:52
Mein ich doch. Dann müsste doch auch meine These Stimmen, dass:
SQL-Code:
select * from A a
    left join B b
        (
            join C c on c.key = b.key
          --join C c on c.key = a.key
        )
    on b.key = a.key;
nicht zwingend dasselbe Ergebnis liefert wie

SQL-Code:
select * from A a
left join B b on b.key = a.key
left join C c on c.key = a.key;
Das zweite liefert alles von A und dazu alles von B was zu A passt und dazu alles von C was zu A passt.

Das erste liefert alles von A und dazu alles von B und C, wo C zu B passt.
Dadurch könnten doch zuvor schon zu A passende Daten von B verloren gehen, da sie nicht zu C passen.
Ralph
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#16

AW: Eingeschobener Join

  Alt 15. Feb 2012, 10:00
Code:
select * from A a
    left join
(B b join C c on c.key = b.key)
    on b.key = a.key;

A = 1,2,3
B = 3,4,5
C = 2,6,7

bc = B join C = ()
A left join bc = (1-x-x, 2-x-x, 3-x-x)

select * from A a
left join B b on b.key = a.key
left join C c on c.key = a.key;

ab = A left join B = (1-x,2-x,3-3)
ab left join C = (1-x-x, 2-x-2, 3-3-x)
Getippt und nicht getestet (bin kein RDMBS)
Die Anzahl der Zeilen ist die Gleiche, aber nicht der Inhalt der Zeilen.


SQL-Code:
select * from A a
    left join (
          B b join C c on c.key = b.key
        )
    on b.key = a.key;
@Iwo Asnet: Danke für die Erklärung mit der Mengenlehre, mit der Explizit hingeschriebenen Klammer wird dies auch sofort deutlich.
Keine Ursache, aber richtig abschreiben musste schon (Klammer war falsch)

Geändert von Iwo Asnet (15. Feb 2012 um 10:09 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 10:43 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