John Lumby wrote:
<  
< Tom Lane wrote
< 
< > > How about replacing "expression [ , ... ]"  by "parameter_list" in the 
description, 
< > > and then stating that parameter_list can be either a single expression or 
, 
< > >  if the particular aggregate function accepts it (for which,   consult 
that function's reference),
< > >   a comma-separated list of expressions.
< > 
< > That's just as wrong.  As we tried to explain before, the
< > parenthesized-list syntax is a row constructor, so it only works
< > in cases where the aggregate function can accept a composite
< > argument type.  Most don't.
< >
< 
< But surely not *all* cases of a multi-expression parameter list of an 
aggregate function are row constructors are they?    What about
< 
< select parent_id, name, GROUPING(parent_id , name), count(*) FROM mytable 
GROUP BY ROLLUP(parent_id , name);
< 
< In the piece "GROUPING(parent_id , name)" ,
<   is "(parent_id , name)"  a row constructor or a list of two expressions?
< 
< Or are you saying those are one and the same thing?
< 

I think I can answer my own question   -  No they are not the same  -   because 
:

select parent_id, name, GROUPING(ROW(parent_id , name)), count(*) FROM mytable 
GROUP BY ROLLUP(parent_id , name);
ERROR:  arguments to GROUPING must be grouping expressions of the associated 
query level
LINE 1: select parent_id, name, GROUPING(ROW(parent_id , name)), cou...
                                         ^




Reply via email to