single
Verwendung von Inneren Unterabfragen im FROM-Abschnitt
Swipe um das Menü anzuzeigen
Eine innere Unterabfrage erstellt eine Tabelle, mit der anschließend Operationen in der äußeren Abfrage durchgeführt werden.
Daraus ergibt sich, dass eine innere Abfrage auch im FROM-Abschnitt verwendet werden kann, um aus dieser Tabelle etwas auszuwählen.
Betrachte ein Beispiel, bei dem mit employees gearbeitet werden soll, deren salary über einem bestimmten Wert liegt. Anstelle einer WHERE-Klausel soll jedoch eine innere Abfrage verwendet werden:
123456SELECT * FROM ( SELECT * From employees WHERE salary >= 70000 ) AS high_salary_employees
Eine neue Tabelle wurde mithilfe einer inneren Unterabfrage erstellt, mit der gearbeitet und Informationen gesammelt werden können.
Beachte, 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, wenn nicht mit der gesamten Tabelle, sondern nur mit einem gefilterten Teil gearbeitet werden soll, ist eine innere Unterabfrage im FROM-Abschnitt äußerst praktisch.
Wischen, um mit dem Codieren zu beginnen
Ihre Aufgabe ist es, das durchschnittliche Budget (Spalte budget) für alle Management-Abteilungen aus der Tabelle department abzurufen. Verwenden Sie dazu eine innere Unterabfrage im FROM-Abschnitt, um nur die Abteilungen vom Typ '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