sql >> Database teknologi >  >> RDS >> Mysql

Gennemsnit på en count() i samme forespørgsel

Dette er den forespørgsel, du udfører, skrevet i en lidt mindre stump syntaks.

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;

Du krydser tabellen, laver (6x6=) 36 rækker i alt og kondenserer dette ned til 4, men fordi det samlede antal er 36, er resultatet forkert.
Det er derfor, du aldrig bør bruge implicitte joinforbindelser.

Omskriv forespørgslen til:

SELECT AVG(a.rcount) FROM 
  (select count(*) as rcount 
   FROM ressursertiloppgave r
   GROUP BY r.ModulID) a

Hvis du vil have den enkelte række og gennemsnittet nederst gør:

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



  1. hvordan kan man sammenkæde strenge?

  2. Django ORM-forespørgsel GROUP BY flere kolonner kombineret med MAX

  3. Få en returværdi i C# asp.net fra en lagret procedure (syntaksproblem)

  4. Oracle 11g:Standard til statisk værdi, når forespørgslen ikke returnerer noget