8.39. SQLAlchemy Query Count

It is important to note that the value returned by count() is not the same as the number of ORM objects that this Query would return from a method such as the .all() method. The Query object, when asked to return full entities, will deduplicate entries based on primary key, meaning if the same primary key value would appear in the results more than once, only one object of that primary key would be present. This does not apply to a query that is against individual columns.

8.39.1. Count

8.39.2. Use Case - 1

Count User records, without sing a subquery

>>> from sqlalchemy import func
>>>
>>>
>>> query = select(func.count(User.id))
>>>
>>> with session.begin() as db:
...     result = db.execute(query)

8.39.3. Use Case - 2

Return count of user 'id' grouped by 'name'

>>> from sqlalchemy import func
>>>
>>>
>>> query = (
...     select(func.count(User.id)).
...     group_by(User.name))
>>>
>>> with session.begin() as db:
...     result = db.execute(query)

8.39.4. Use Case - 2

Count distinct 'name' values

>>> from sqlalchemy import func
>>> from sqlalchemy import distinct
>>>
>>>
>>> query = (
...     select(func.count(distinct(User.id)).
...     group_by(User.name)))
>>>
>>> with session.begin() as db:
...     result = db.execute(query)