AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Befehl über mehrere Tabellen
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Befehl über mehrere Tabellen

Ein Thema von Luca Haas · begonnen am 27. Feb 2018 · letzter Beitrag vom 27. Feb 2018
Antwort Antwort
Seite 2 von 2     12   
jobo

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

AW: SQL Befehl über mehrere Tabellen

  Alt 27. Feb 2018, 13:26
Irgendwie kann ich mich mit dieser "altmodischen" Form des JOIN nicht richtig anfreunden.

Hat das DBMS vielleicht ein Problem, weil der JOIN auf R kommt, bevor R1 gejoint wurde, weil die DB die joins auch auf ähnliche Art versucht aufzulösen / zu optimieren.
Oder wird erstmal ALLES blind mit FULL JOIN genommen und dann das WHERE drüber?

Nja, tausch einfach mal versuchsweise Reihenfolge von Rechnung_s und Rechnungpos_s.

Bei dieser FORM kannst du auch probehalber ein ON true-- einfügen oder aus einem JOIN einen LEFT JOIN machen.
abwechselnd bei allen JOINs und so schauen wer hängt, also wo dann plötzlich Daten auftauchen.
Die "alte" Form ist eigentlich Oracle Style, zumindest gibt es (nur?) hier das (+) für outer joins. Weiß nicht ob MS da anfags auch eine Analogie gebastelt hat, aber vielleicht haben sie direkt nur "outer join" Syntax implementiert.
Die "alte" Form geht natürlich immer und überall, wenn outer (oder noch krasser) nicht gebraucht wird.

Die "Reihenfolge" sollte oder besser darf für die Ausgabe absolut keine Rolle spielen, wenn doch, Datenbank wegwerfen. Es gibt Optimizer (z.B. der alte von Oracle 8), die anhand der Reihenfolge in der From Clause einen Ausführungsplan aufbauen. Der Entwickler kann da so direkt Einfluss nehmen, wenn es denn bekannt ist und keine anderen Katastrophen eintreten.

Einfach mal schauen und ausprobieren find ich auch immer gut- na wo sind denn die ganzen Rechnungen?-, am besten find ich es sogar mit ein paar handverlesenen Datensätzen, also in fast leeren Tabellen. Damit kann man sich ganz intuitiv die Bedeutung der Joins klar machen.

Apropos: Die Where Clause sollte in der neuen Syntax nur noch zum Filtern eingesetzt werden. Das kann versehentlich schief gehen, wenn man mit Outer Joins arbeitet.
Gruß, Jo
  Mit Zitat antworten Zitat
Jumpy

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

AW: SQL Befehl über mehrere Tabellen

  Alt 27. Feb 2018, 13:41
Die "Reihenfolge" sollte oder besser darf für die Ausgabe absolut keine Rolle spielen, wenn doch, Datenbank wegwerfen.
Der Datenbank ist das natürlich egal, aber dem Entwickler, der seine Statements logisch aufbaut vielleicht nicht:

Aufgabenstellung: Gewicht und Kosten aller Artikel aus dem letzten Jahr.
Dann ist mMn die Vorgehensweise beim Entwickeln des Statements:

Erst alle Rechnungen nehmen, Einschränkung auf das Jahr.
Dazu die Rechnungspositionen, reicht ein Left Join.
Wenn jeder Position ein Artikel entspricht, dann Artikeldetails dazu holen, wieder reicht ein Left Join.
Jetzt wie gewünscht Gruppieren/Summieren.
Wenn eine Auftragsposition noch eine Mengenangabe/Anzahl hat, das ggf. mit berücksichtigen.

Die Abfage funktioniert so vllt. nicht besser oder schneller, aber einem selber wird mMn klarer, was man da gerade macht.
Ralph
  Mit Zitat antworten Zitat
jobo

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

AW: SQL Befehl über mehrere Tabellen

  Alt 27. Feb 2018, 16:19
Ich denke, das ist dann am Ende eine Mischung aus der "eigenen" gedanklichen Reihenfolge und den Gegebenheiten, also Datenmodell.
Was man machen würde, ist die eine Sache, was man zur Verfügung hat die andere. Am intuitivsten geht es dann vermutlich mit einem selbst geschaffenen Datenmodell.
Ich selbst nutze gern Verschachtelung, setze alles was klar ist und easy in Klammern und friemel dann mit dem Klammerergebnis die borstigen Sachen zusammen, letztlich als ob man mit Views arbeiten würde. Meine Reihenfolge wäre also da von einfach nach kompliziert.
Gruß, Jo
  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 15:08 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz