sql >> Database >  >> RDS >> Mysql

Alle berichten tellen die tot een categorie EN zijn subcategorieën behoren

Als de categorieën niet oneindig genest zijn, kunt u er één niveau tegelijk aan deelnemen. Hier is een voorbeeld voor maximaal 3 nestniveaus:

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


  1. Langzame eenvoudige update-query op PostgreSQL-database met 3 miljoen rijen

  2. Hoe groot kan een MySQL-database worden voordat de prestaties achteruit gaan?

  3. kruistabel met 2 (of meer) rijnamen

  4. MySQL-tabel voor breedtegraad en lengtegraad