Re: Simple aggregate query brain fart - Mailing list pgsql-sql

From Tom Lane
Subject Re: Simple aggregate query brain fart
Date
Msg-id 11074.1268925073@sss.pgh.pa.us
Whole thread Raw
In response to Simple aggregate query brain fart  (Mark Fenbers <Mark.Fenbers@noaa.gov>)
Responses Re: Simple aggregate query brain fart  (Mark Fenbers <Mark.Fenbers@noaa.gov>)
List pgsql-sql
Mark Fenbers <Mark.Fenbers@noaa.gov> writes:
> I want to do:
> SELECT id, count(*) FROM mytable WHERE count(*) > 2 GROUP BY id;

> But this doesn't work because Pg won't allow aggregate functions in a 
> where clause.

Use HAVING, not WHERE.  The way you are trying to write the query is
meaningless because WHERE filters rows before grouping/aggregation.
HAVING filters afterwards, which is when it makes sense to put a
condition on count(*).
        regards, tom lane


pgsql-sql by date:

Previous
From: "Plugge, Joe R."
Date:
Subject: Re: Simple aggregate query brain fart
Next
From: Mark Fenbers
Date:
Subject: Re: Simple aggregate query brain fart