Unterabfragen SQL
Guten Tag,
es ist mir nicht ganz verstädnlich, wann man in SQL eine Unterabfrage macht bzw. wann es Sinn macht. Dies möchte ich am folgenden Beispiel verdeutlichen:
Richtig lautet es:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge >
(SELECT
Länge
FROM
tblFilme
WHERE
Filmtitel ='Gladiator')
ORDER BY tblFilme.Länge DESC
Ich hätte gedachzt es würde auch so gehen:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge > Filmtitel ='Gladiator'
ORDER BY tblFilme.Länge DESC
Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
es ist mir nicht ganz verstädnlich, wann man in SQL eine Unterabfrage macht bzw. wann es Sinn macht. Dies möchte ich am folgenden Beispiel verdeutlichen:
Richtig lautet es:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge >
(SELECT
Länge
FROM
tblFilme
WHERE
Filmtitel ='Gladiator')
ORDER BY tblFilme.Länge DESC
Ich hätte gedachzt es würde auch so gehen:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge > Filmtitel ='Gladiator'
ORDER BY tblFilme.Länge DESC
Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 196046
Url: https://administrator.de/forum/unterabfragen-sql-196046.html
Ausgedruckt am: 23.12.2024 um 05:12 Uhr
3 Kommentare
Neuester Kommentar
Hi,
bei der oberen Abfrage fragst du nach dem Wert "Länge" vom Filmtitel "Gladiator",
dies ist ja auch das was du als Vergleichsgröße benötigst.
Unten kann die Abfrage nicht funktionieren, da du kein eindeutiges Ergebnis hast mit dem du größer als vergleichst.
Richtig wäre auch, wenn du in der Abfrage direkt den Wert angeben würdest, also:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge > 150
ORDER BY tblFilme.Länge DESC
jenachdem was als Wert in Länge angegeben ist.
Da du aber einen Wert vergleichen willst, welcher selber nur über eine Abfrage zu erreichen ist,
daher die nötige Unterabfrage.
Greetz
Firepower
bei der oberen Abfrage fragst du nach dem Wert "Länge" vom Filmtitel "Gladiator",
dies ist ja auch das was du als Vergleichsgröße benötigst.
Unten kann die Abfrage nicht funktionieren, da du kein eindeutiges Ergebnis hast mit dem du größer als vergleichst.
Richtig wäre auch, wenn du in der Abfrage direkt den Wert angeben würdest, also:
SELECT
tblFilme.Filmtitel, tblFilme.Länge
FROM
tblFilme
WHERE
tblFilme.Länge > 150
ORDER BY tblFilme.Länge DESC
jenachdem was als Wert in Länge angegeben ist.
Da du aber einen Wert vergleichen willst, welcher selber nur über eine Abfrage zu erreichen ist,
daher die nötige Unterabfrage.
Greetz
Firepower
Hallo,
Im besten Fall würde "Filmtitel = 'Gladiator'" eine ganze Zeile zurückliefern, und eine Zelle (tblFilme.Länge) kannst du nicht mit einer Zeile vergleichen.
Gruß
Filipp
Ich hätte gedachzt es würde auch so gehen: [...]
Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
Äh... ne. Kannst du erklären, wie du auf die Idee kommst, dass es funktionieren sollte?Leider ist dies nicht der Fall. Kann mir jeman derklären woran das liegt?
Im besten Fall würde "Filmtitel = 'Gladiator'" eine ganze Zeile zurückliefern, und eine Zelle (tblFilme.Länge) kannst du nicht mit einer Zeile vergleichen.
Gruß
Filipp