Ответ 1
Это запрос, который вы выполняете, написанный в чуть менее тупой синтаксисе.
SELECT
avg(a.ress) as GjSnitt
, modulID
FROM
(SELECT COUNT(ressursID) as ress
FROM ressursertiloppgave
GROUP BY modulID) as a
CROSS JOIN ressursertiloppgave r <--- Cross join are very very rare!
GROUP BY modulID;
Вы переходите к таблице, делая (6x6 =) 36 строк в общей сложности и уменьшая это до 4, но поскольку общее количество составляет 36, результат неверен.
Вот почему вы никогда не должны использовать неявные объединения.
Перепишите запрос на:
SELECT AVG(a.rcount) FROM
(select count(*) as rcount
FROM ressursertiloppgave r
GROUP BY r.ModulID) a
Если вы хотите, чтобы отдельная строка и находилась в среднем внизу:
SELECT r1.ModulID, count(*) as rcount
FROM ressursertiloppgave r1
GROUP BY r1.ModulID
UNION ALL
SELECT 'avg = ', AVG(a.rcount) FROM
(select count(*) as rcount
FROM ressursertiloppgave r2
GROUP BY r2.ModulID) a