Wystarczy przenieść WHERE
klauzula do wewnętrznego zapytania.
SELECT TeacherID, UniversityID, RowNum FROM
(
SELECT a.TeacherID, a.UniversityID, ROW_NUMBER() OVER
(ORDER BY a.TeacherID) AS RowNum FROM SelectAll a
LEFT JOIN mp_Ratings r
ON a.TeacherID = r.TeacherID
WHERE UniversityID = 2
GROUP BY a.TeacherID, a.UniversityID
) as TeacherInfo WHERE RowNum BETWEEN 10 AND 50;
Nie masz dostępu do RowNum
alias w zewnętrznej wersji zapytania, ponieważ alias jeszcze nie istnieje. SELECT
jest analizowany jako przedostatni, przed ORDER BY
. WHERE
jest przetwarzany przed SELECT
.