Verwendung von Inneren Unterabfragen im FROM-Abschnitt
Eine innere Unterabfrage erstellt eine Tabelle, mit der anschließend in der äußeren Abfrage Operationen durchgeführt werden.
Daraus lässt sich schließen, dass eine innere Abfrage auch im FROM-Abschnitt verwendet werden kann, um aus dieser Tabelle Daten auszuwählen.
Betrachten wir ein Beispiel, in dem mit employees gearbeitet werden soll, deren salary über einem bestimmten Wert liegt. Anstelle einer WHERE-Klausel wird jedoch eine innere Abfrage verwendet:
123456SELECT * FROM ( SELECT * From employees WHERE salary >= 70000 ) AS high_salary_employees
Es wurde eine neue Tabelle mithilfe einer inneren Unterabfrage erstellt, mit der gearbeitet und Informationen gesammelt werden können.
Beachten Sie, dass es bei einer solchen Tabelle unerlässlich ist, einen Alias anzugeben.
Wann ist dies nützlich?
Eine solche Abfrage ist sehr gut lesbar; manchmal kann sie eine WHERE-Klausel ersetzen.
Außerdem ist eine innere Unterabfrage im FROM-Abschnitt äußerst praktisch, wenn Sie nicht mit der gesamten Tabelle, sondern nur mit einem gefilterten Teil arbeiten müssen.
Swipe to start coding
Ihre Aufgabe ist es, das durchschnittliche Budget (Spalte budget) für alle Management-Abteilungen aus der Tabelle department abzurufen. Verwenden Sie eine innere Unterabfrage im FROM-Abschnitt, um nur den Abteilungstyp 'manager' zu filtern. Verwenden Sie außerdem den Alias manager_departments für diese Tabelle, damit die Aufgabe korrekt überprüft werden kann.
Die Antwort soll nur eine Spalte mit dem Namen average_budget enthalten. Dies ist ein Alias für die Aggregatfunktion AVG().
Diese Aufgabe könnte auch mit einer WHERE-Klausel gelöst werden, aber wir verwenden hier eine verschachtelte Abfrage, um diese Syntax zu üben, die für die Lösung komplexerer Probleme in Zukunft nützlich sein wird.
Kurzanleitung
- Abrufen des Durchschnittswerts der Spalte
budget. - Zuweisung des Alias
average_budgetzu dieser Spalte. - Im
FROM-Abschnitt muss eine verschachtelte Abfrage geschrieben werden. - In der verschachtelten Abfrage alle Spalten aus der Tabelle
departmentauswählen. - In der verschachtelten Abfrage die
WHERE-Klausel mit der Bedingungtype = 'manager'verwenden. - Der verschachtelten Abfrage den Alias
manager_departmentszuweisen.
Lösung
Danke für Ihr Feedback!
single
Fragen Sie AI
Fragen Sie AI
Fragen Sie alles oder probieren Sie eine der vorgeschlagenen Fragen, um unser Gespräch zu beginnen
Großartig!
Completion Rate verbessert auf 4
Verwendung von Inneren Unterabfragen im FROM-Abschnitt
Swipe um das Menü anzuzeigen
Eine innere Unterabfrage erstellt eine Tabelle, mit der anschließend in der äußeren Abfrage Operationen durchgeführt werden.
Daraus lässt sich schließen, dass eine innere Abfrage auch im FROM-Abschnitt verwendet werden kann, um aus dieser Tabelle Daten auszuwählen.
Betrachten wir ein Beispiel, in dem mit employees gearbeitet werden soll, deren salary über einem bestimmten Wert liegt. Anstelle einer WHERE-Klausel wird jedoch eine innere Abfrage verwendet:
123456SELECT * FROM ( SELECT * From employees WHERE salary >= 70000 ) AS high_salary_employees
Es wurde eine neue Tabelle mithilfe einer inneren Unterabfrage erstellt, mit der gearbeitet und Informationen gesammelt werden können.
Beachten Sie, dass es bei einer solchen Tabelle unerlässlich ist, einen Alias anzugeben.
Wann ist dies nützlich?
Eine solche Abfrage ist sehr gut lesbar; manchmal kann sie eine WHERE-Klausel ersetzen.
Außerdem ist eine innere Unterabfrage im FROM-Abschnitt äußerst praktisch, wenn Sie nicht mit der gesamten Tabelle, sondern nur mit einem gefilterten Teil arbeiten müssen.
Swipe to start coding
Ihre Aufgabe ist es, das durchschnittliche Budget (Spalte budget) für alle Management-Abteilungen aus der Tabelle department abzurufen. Verwenden Sie eine innere Unterabfrage im FROM-Abschnitt, um nur den Abteilungstyp 'manager' zu filtern. Verwenden Sie außerdem den Alias manager_departments für diese Tabelle, damit die Aufgabe korrekt überprüft werden kann.
Die Antwort soll nur eine Spalte mit dem Namen average_budget enthalten. Dies ist ein Alias für die Aggregatfunktion AVG().
Diese Aufgabe könnte auch mit einer WHERE-Klausel gelöst werden, aber wir verwenden hier eine verschachtelte Abfrage, um diese Syntax zu üben, die für die Lösung komplexerer Probleme in Zukunft nützlich sein wird.
Kurzanleitung
- Abrufen des Durchschnittswerts der Spalte
budget. - Zuweisung des Alias
average_budgetzu dieser Spalte. - Im
FROM-Abschnitt muss eine verschachtelte Abfrage geschrieben werden. - In der verschachtelten Abfrage alle Spalten aus der Tabelle
departmentauswählen. - In der verschachtelten Abfrage die
WHERE-Klausel mit der Bedingungtype = 'manager'verwenden. - Der verschachtelten Abfrage den Alias
manager_departmentszuweisen.
Lösung
Danke für Ihr Feedback!
single