Mehrere CTEs in einer einzigen SQL-Abfrage
In SQL ist es möglich, mehrere CTEs (Common Table Expressions) in einer einzigen Abfrage zu kombinieren . Um dies zu erreichen, müssen Sie das Schlüsselwort WITH einmal am Anfang der Abfrage verwenden.
Beispiel:
Angenommen, Sie möchten kombinieren ein rekursiver CTE und zwei nicht rekursive CTEs. Sie können dies mit der folgenden Syntax tun:
WITH RECURSIVE cte1 AS (...), cte2 AS ( SELECT ... UNION ALL SELECT ... ), cte3 AS (...) SELECT ... FROM cte3 WHERE ...
In diesem Beispiel:
Hinweis: Die Reihenfolge der CTEs ist bei REKURSIV nicht von Bedeutung Schlüsselwort wird verwendet.
Rekursiv CTE:
Ein rekursiver CTE kann in seiner Definition auf sich selbst verweisen. Dadurch können Sie hierarchische oder baumartige Strukturen aufbauen. Im obigen Beispiel ist cte2 ein rekursiver CTE, da er in der UNION ALL-Klausel auf sich selbst verweist.
Nicht-rekursive CTEs:
Nicht -rekursive CTEs definieren einfach temporäre Tabellen, auf die später in der Abfrage verwiesen werden kann. Im obigen Beispiel sind cte1 und cte3 nicht rekursive CTEs.
Das obige ist der detaillierte Inhalt vonWie kann ich mehrere CTEs, einschließlich rekursiver, in einer einzigen SQL-Abfrage kombinieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!