SQL WITH | |
Manchmal steht man vor einer komplexen Frage, die nicht einfach mit einer einzelnen SQL-Anweisung beantwortet werden kann. Man könnte versuchen, die Antwort in einem Durchlauf zu erhalten, indem man mehrere Inline-Ansichten oder mehrere Unterabfragen verwendet, aber das wird wahrscheinlich dazu führen, dass der SQL-Code schwer verständlich wird, und einige SQL-Varianten, wie z.B. Hive SQL, erlauben keine mehrfachen Unterabfragen. Ein zweiter Ansatz besteht darin, die Komplexität in mehrere Schritte aufzuteilen. Eine Möglichkeit, dies zu tun, besteht darin, mehrere Tabellen zu erstellen, wobei jede Tabelle die Ergebnisse eines jeden Schritts speichert. Dies ist oft eine gute Strategie, da dies die Fehlersuche erleichtert und das Verfolgen der Ausführung des Codes einfacher wird. Allerdings ist der unerwünschte Nebeneffekt, dass man sich daran erinnern muss, diese Tabellen nach Abschluss der Analyse zu löschen; andernfalls verbleiben diese Tabellen in der Datenbank und führen zu Problemen bei der Datenbankverwaltung. Die Alternative zur Erstellung mehrerer Tabellen besteht darin, die WITH-Klausel in SQL zu verwenden. SyntaxDie grundlegende Syntax für die WITH-Klausel sieht wie folgt aus: WITH <Abfrage_Name_1> AS (
SELECT-Anweisung 1 ) Haupt SELECT-Anweisung Die Verwendung der WITH-Klausel ähnelt sehr der Erstellung von Tabellen. Wenn Sie eine Tabelle erstellen, geben Sie ihr einen Namen. Ebenso, wenn Sie die WITH-Klausel verwenden, geben Sie ihr ebenfalls einen Namen, und dieser Name fungiert im Wesentlichen wie ein Tabellenname in der Haupt-SQL-Anweisung. Da die WITH-Klausel keine Tabelle oder Ansicht erstellt, verschwindet das Objekt, das mit der WITH-Anweisung verknüpft ist, nachdem die Haupt-SQL-Anweisung ausgeführt wurde, und es gibt nichts zu bereinigen. Sie können auch mehrere WITH-Klauseln haben. Die Syntax lautet wie folgt: WITH <Abfrage_Name_1> AS (
SELECT-Anweisung 1 ), <Abfrage_Name_2> AS ( SELECT-Anweisung 2 ), .. <Abfrage_Name_N> AS ( SELECT-Anweisung N ) Haupt SELECT-Anweisung Um mehrere WITH-Klauseln zu haben, müssen Sie die WITH-Klausel nicht mehrmals angeben. Stattdessen fügen Sie nach Abschluss der ersten WITH-Klausel ein Komma hinzu, und dann können Sie die nächste Klausel angeben, indem Sie mit <Abfrage_Name> gefolgt von ALS beginnen. Es gibt kein Komma zwischen der letzten WITH-Klausel und der Haupt-SQL-Anfrage. BeispieleWir verwenden die folgende Tabelle in unseren Beispielen. Tabelle Store_Sales
Beispiel 1: Verwendung von WITH in einer SELECT-AnweisungAngenommen, wir möchten alle Geschäfte auflisten, die mehr Umsatz als der Durchschnitt haben. Dazu können wir die folgende WITH-Anweisung verwenden: WITH t1 AS (
SELECT AVG(Sales) AVG_SALES FROM Store_Sales ) SELECT a1.* FROM Store_Sales a1, t1 WHERE a1.Sales > t1.AVG_SALES; Ergebnis:
Die WITH-Anweisung berechnet den durchschnittlichen Umsatzbetrag (der $6.875 beträgt), und dann gibt die Haupt-SQL-Anfrage einfach alle Zeilen zurück, bei denen der Wert in der Spalte Umsatz größer ist als dieser Durchschnittsbetrag. Ein äquivalenter SQL mit Inline-Ansicht wäre: SELECT a1.* FROM Store_Sales a1,
(SELECT AVG(Sales) AVG_SALES FROM Store_Sales) t1 WHERE a1.Sales > t1.AVG_SALES; Ebenso kann dies durch den folgenden SQL unter Verwendung einer Unterabfrage erreicht werden: SELECT a1.* FROM Store_Sales a1
WHERE a1.Sales > (SELECT AVG(Sales) AVG_SALES FROM Store_Sales); Beachten Sie, dass die Version mit Unterabfrage in Hive SQL aufgrund der Art und Weise, wie Hive SQL Unterabfragen unterstützt, nicht funktioniert. Beispiel 2: Verwenden von WITH in einer CREATE TABLE-AnweisungWir können WITH auch zusammen mit einer CREATE TABLE-Anweisung verwenden. Angenommen, wir möchten eine Tabelle mit der WITH-Klausel aus dem vorherigen Beispiel erstellen, würden wir folgendes eingeben: CREATE TABLE Above_Average_Sales
AS WITH t1 AS ( SELECT AVG(Sales) AVG_SALES FROM Store_Sales ) SELECT a1.* FROM Store_Sales a1, t1 WHERE a1.Sales > t1.AVG_SALES; Der WITH-Teil der Abfrage erfolgt nach CREATE TABLE AS. Die WITH-Klausel sollte nicht am Anfang stehen. Die folgende Abfrage wird einen Fehler verursachen: WITH t1 AS (
SELECT AVG(Sales) AVG_SALES FROM Store_Sales ) CREATE TABLE Above_Average_Sales AS SELECT a1.* FROM Store_Sales a1, t1 WHERE a1.Sales > t1.AVG_SALES;
Copyright © 2025 1keydata.com Alle Rechte vorbehalten |