Konventionelle Praktiken erfordern oft die Kombination mehrerer Common Table Expressions (CTEs), um komplexe Datenabrufaufgaben zu erfüllen. Es bestehen jedoch weiterhin Zweifel an der Machbarkeit der Kombination mehrerer CTEs in einer einzigen SQL-Abfrage.
Tatsächlich ist es durchaus möglich, mehrere CTEs in einer einzigen SQL-Abfrage zu kombinieren. Die Syntax erfordert die Verwendung des Schlüsselworts WITH nur einmal, positioniert am Anfang der Abfrage. Selbst wenn es sich um eine Mischung aus rekursiven und nicht rekursiven CTEs handelt, sollte das Schlüsselwort RECURSIVE immer noch nur einmal oben enthalten sein.
Zum Beispiel:
WITH RECURSIVE cte1 AS (...) -- non-recursive , cte2 AS (SELECT ... UNION ALL SELECT ...) -- recursive , cte3 AS (...) SELECT ... FROM cte3 WHERE ...
Es ist bemerkenswert, dass die Reihenfolge von CTE-Klauseln wird irrelevant, wenn das Schlüsselwort RECURSIVE vorhanden ist. Gemäß dem SQL-Handbuch können CTE-Abfragen unabhängig von ihrer Reihenfolge innerhalb der WITH-Klausel auf andere CTEs verweisen.
Außerdem nicht rekursive CTEs, auf die in der endgültigen SELECT-Anweisung nicht verwiesen wird und dies auch nicht der Fall ist etwaige Nebeneffekte werden nicht ausgeführt.
Das obige ist der detaillierte Inhalt vonKönnen mehrere CTEs in einer einzigen SQL-Abfrage kombiniert werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!