Hallo Leute,
ich habe ein kleines Problem. Ich möchte nämlich eine relativ komplexe SQL-Abfrage durchführen und muss dafür in einer Subquery einen speziellen Datensatz auslesen. Das fällt mir derzeit allerdings etwas schwer.
Hier ein Minimal-Beispiel:
Das Problem ist nun, dass ich nicht auf tjdata.Timestamp in dem inneren Select zugreifen kann. Gibt es ne Möglichkeit das dennoch so oder so ähnlich zu machen oder ist es zwingend notwendig, dass ich da noch weitere wilde joins innerhalb des inneren Select mache?Code (MySQL):
EDIT: Lösungsansatz
Kaum stellt man hier eine Frage, findet man auch schon eine Lösung.
Nutzt man PostGreSQL, so kann man an das letzte JOIN ein LATERAL anhängen, welches auch Felder aus dem Outer-Query bereitstellt.
Eine andere Lösung für SQL-Server wäre wohl das Keyword APPLY, welches mehr oder minder die gleiche Funktion erfüllt.Code (PostgreSQL):
SELECT tjdata.Timestamp AS Timestamp,tslimit.LLimit AS LowerLimit FROM table1 AS tjdata INNER JOIN table3 AS tsinfo ON tjdata.InfoId = tsInfo.ID INNER JOIN LATERAL (SELECT `ID`, `LLimit` FROM table2 WHERE `Date` >= tjdata.Timestamp ORDER BY `Date` ASC LIMIT 1) AS tslimit ON tsinfo.ID = tslimit.InfoId WHERE tsinfo.Name="Foo";
Für MySql oder MariaDb muss man anscheinend die Query anscheinend etwas anders aufbauen:
Indem man das Innere Select nicht mehr innerhalb des Joins direkt verwendet und es damit keine "Derived Table" mehr erstellt, ist es möglich auf Felder aus dem Outer-Select zuzugreifen.Code (MySQL):
Zur Performance kann ich allerdings nichts sagen. Ich vermute, dass die MySQL-Lösung in diesem Fall langsamer ist als die von PostGreSQL und ähnlichen.