• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

SQL Subquery mit Feld aus Outer-Query

Roin

Freier Denker

Registriert
22 Juli 2013
Beiträge
581
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:

[src=mysql]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
(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";[/src]

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?

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.
[src=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";
[/src]

Eine andere Lösung für SQL-Server wäre wohl das Keyword APPLY, welches mehr oder minder die gleiche Funktion erfüllt.
Für MySql oder MariaDb muss man anscheinend die Query anscheinend etwas anders aufbauen:
[src=mysql] 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 table2 AS tslimit ON tsinfo.ID = tslimit.InfoId AND tslimit.ID =
(SELECT `ID`FROM table2 WHERE `Date` >= tjdata.Timestamp ORDER BY `Date` ASC LIMIT 1)
WHERE tsinfo.Name="Foo";
[/src]

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.
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.
 
Zuletzt bearbeitet:
Oben