Re: description of Aggregate Expressions
От | John Lumby |
---|---|
Тема | Re: description of Aggregate Expressions |
Дата | |
Msg-id | DM6PR06MB55625AB1CB94FD039E1EEB0BA35F0@DM6PR06MB5562.namprd06.prod.outlook.com обсуждение исходный текст |
Ответ на | Re: description of Aggregate Expressions (John Lumby <johnlumby@hotmail.com>) |
Список | pgsql-docs |
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... ^
В списке pgsql-docs по дате отправления: