소스 검색

MAX in WHERE not possible

You cannot use MAX() in a WHERE clause, instead use a subquery.

The ORDER BY is also unneeded, because we only select the maximum. So what to order, there is only one number (even if multiple entries with the same number).
Stefan Koch 12 년 전
부모
커밋
097d360423
1개의 변경된 파일1개의 추가작업 그리고 2개의 파일을 삭제
  1. 1 2
      documents/musterloesung-db-klausur-b/d3e.sql

+ 1 - 2
documents/musterloesung-db-klausur-b/d3e.sql

@@ -1,5 +1,4 @@
 SELECT berater_id, name, anzahl
     FROM Beratungsanzahl
     JOIN Berater ON Berater.berater_id = Beratungsanzahl.berater_id
-    WHERE anzahl = MAX(anzahl)
-    ORDER BY anzahl DESC
+    WHERE anzahl = (SELECT MAX(anzahl) FROM Beratungsanzahl)