SQL - HAVING と WHERE 質問する

SQL - HAVING と WHERE 質問する

次の 2 つのテーブルがあります。

1. Lecturers (LectID, Fname, Lname, degree).
2. Lecturers_Specialization (LectID, Expertise).

最も専門性の高い講師を見つけたいのですが、これを試してもうまくいきません。

SELECT
  L.LectID, 
  Fname, 
  Lname 
FROM Lecturers L, 
     Lecturers_Specialization S
WHERE L.LectID = S.LectID
AND COUNT(S.Expertise) >= ALL (SELECT
  COUNT(Expertise)
FROM Lecturers_Specialization
GROUP BY LectID);

しかし、これを試してみると、うまくいきます:

SELECT
  L.LectID,
  Fname,
  Lname 
FROM Lecturers L,
     Lecturers_Specialization S
WHERE L.LectID = S.LectID
GROUP BY L.LectID,
         Fname,
         Lname 
HAVING COUNT(S.Expertise) >= ALL (SELECT
  COUNT(Expertise)
FROM Lecturers_Specialization
GROUP BY LectID); 

理由は何ですか?ありがとうございます。

ベストアンサー1

WHERE句は個々の行に条件を導入します。句は集計、つまり、カウント、平均、最小、最大、合計などの単一の結果が複数のHAVING行から生成された選択の結果に条件を導入します。クエリは 2 番目の種類の条件 (つまり、集計の条件) を要求しているため、正しく機能します。HAVING

経験則として、WHEREbeforeGROUP BYHAVINGafterを使用しますGROUP BY。これはかなり原始的なルールですが、90% 以上のケースで役立ちます。

ついでに、ANSI バージョンの結合を使用してクエリを書き直すこともできます。

SELECT  L.LectID, Fname, Lname
FROM Lecturers L
JOIN Lecturers_Specialization S ON L.LectID=S.LectID
GROUP BY L.LectID, Fname, Lname
HAVING COUNT(S.Expertise)>=ALL
(SELECT COUNT(Expertise) FROM Lecturers_Specialization GROUP BY LectID)

これにより、シータ結合条件WHEREとして使用されていた が排除されます。

おすすめ記事