Avatar billede horizon Nybegynder
02. november 2008 - 22:28 Der er 2 kommentarer og
1 løsning

invalid use of group function

Jeg får fejlmeddelelsen "invalid use of group function" når jeg kører denne query:

SELECT
( SUM(stjerner.Stjerner) / COUNT(stjerner.Stjerner) ) AS Stjerner,
bruger.Brugernavn,
COUNT(billeder.ID_BILLEDE) AS Billeder,
album.ID_ALBUM,
album.Titel,
album.ID_BRUGER,
DATE_FORMAT(album.`oprettet`, "'.$txt['10'].'%d.%m.%Y, '.$txt['9'].'%H:%i:%s") AS `Oprettet`,
DATE_FORMAT(album.`sidstOpdateret`, "'.$txt['10'].'%d.%m.%Y, '.$txt['9'].'%H:%i:%s") AS `SidstOpdateret`
FROM
`'.$mySQL[Praefix].'Albums` AS `album`
LEFT JOIN
`'.$mySQL[Praefix].'Stjerner` AS stjerner ON album.ID_ALBUM = stjerner.ID_ALBUM
LEFT JOIN
`'.$mySQL[Praefix].'Billeder` AS billeder ON album.ID_ALBUM = billeder.ID_ALBUM
JOIN
`'.$mySQL[Praefix].'Brugere` AS bruger ON album.ID_BRUGER = bruger.ID_BRUGER
WHERE
album.`Tilladelse` = 1 AND COUNT(billeder.ID_BILLEDE) > 0
GROUP BY
album.ID_ALBUM
ORDER BY
`'.$orderBy.'` '.$opNed.'
LIMIT
'.(($visSide - 1) * indstilling('antalAlbumPrSide')).', '.indstilling('antalAlbumPrSide')

Hvis jeg ændrer WHERE til bare at hedde Tilladelse = 1 så virker den fint, men jeg vil gerne kun hente de album hvor der er billeder i.

Jeg har også prøvet at sige WHERE Billeder > 0 eftersom jeg jo har lavet en COUNT() AS Billeder i min select, men det kunne den ikke.
Avatar billede erikjacobsen Ekspert
02. november 2008 - 22:30 #1
...
WHERE
album.`Tilladelse` = 1
GROUP BY
album.ID_ALBUM
HAVING v
ORDER BY
...
Avatar billede erikjacobsen Ekspert
02. november 2008 - 22:30 #2
Ups

...
WHERE
album.`Tilladelse` = 1
GROUP BY
album.ID_ALBUM
HAVING COUNT(billeder.ID_BILLEDE) > 0
ORDER BY
...
Avatar billede horizon Nybegynder
02. november 2008 - 22:48 #3
Bukker og takker :-)

Kender jeg dig ret vil du ikke have points
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester