Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comptabiliser tous les posts appartenant à une catégorie ET ses sous-catégories

Si les catégories ne sont pas imbriquées à l'infini, vous pouvez les REJOINDRE un niveau à la fois. Voici un exemple pour jusqu'à 3 niveaux d'imbrication :

SELECT c.name, COUNT(DISTINCT p.PID) as postCount 
FROM categories AS c 
LEFT JOIN categories AS c2
    ON c2.parent = c.catid
LEFT JOIN categories AS c3
    ON c3.parent = c2.catid
LEFT JOIN posts AS p 
    ON c.CATID = p.category
    OR c2.CATID = p.category
    OR c3.CATID = p.category
WHERE c.parent = '0' 
GROUP BY c.CATID, c.name
ORDER BY c.name ASC