How to count items per category?

20,376

Solution 1

Try:

SELECT category, COUNT(*) as count FROM table GROUP BY category

The response should be all the different category values, and the number of occurrences of each.

Solution 2

How about this

SELECT field1, count(1) as Total
FROM myTable
GROUP BY field1

Solution 3

Use COUNT() with the GROUP BY to group them together by category

Share:
20,376
romvlads
Author by

romvlads

Updated on May 22, 2020

Comments

  • romvlads
    romvlads about 4 years

    I want to make a filtering of products on a site. Something like this:

    Department
    - lassics (13,395)
    - Literary (111,399)
    - History (68,606)
    ...
    
    Format
    - HTML (3,637)
    - PDF (8)
    - Audio CD (443)
    ...
    
    Language
    - English (227,175)
    - German (10,843)
    - French (10,488)
    ...
    

    How to count products per category? A separate SQL-query for each category would be too slow because there are too many products and categories. I suggest caching is not an option too.

    Maybe it makes sense to use MySQL EXPLAIN queries (though it not always provide adequate information)? Or maybe using sphinx search engine for counting?... What is the best way to do this? Thanks.