Re: pg, mysql comparison with "group by" clause

Поиск
Список
Период
Сортировка
От Greg Stark
Тема Re: pg, mysql comparison with "group by" clause
Дата
Msg-id 87br1u1jvq.fsf@stark.xeocode.com
обсуждение исходный текст
Ответ на Re: pg, mysql comparison with "group by" clause  (Stephan Szabo <sszabo@megazone.bigpanda.com>)
Ответы Re: pg, mysql comparison with "group by" clause
Список pgsql-sql
Stephan Szabo <sszabo@megazone.bigpanda.com> writes:

> On Tue, 11 Oct 2005, Rick Schumeyer wrote:
> 
> > I'm not sure what I was thinking, but I tried the following query in pg:
> >
> > SELECT * FROM t GROUP BY state;
> >
> > pg returns an error.
> >
> > Mysql, OTOH, returns the first row for each state.  (The first row with
> > "AK", the first row with "PA", etc.)
> >
> > I'm no SQL expert, but it seems to me that the pg behavior is correct, and
> > the mysql result is just weird.  Am I correct?
> 
> In your case, it sounds like the mysql result is wrong. I believe SQL99
> would allow it if the other columns were functionally dependant upon state
> (as there'd by definition only be one value for the other columns per
> group).

I believe this is a documented feature.

MySQL treats "select a,b from t group by a" equivalently to Postgres's 
"select distinct on (a) a,b from t"

I suppose "equivalent" isn't quite true. It's more general since it allows
aggregate functions as well. The equivalently general Postgres syntax is to
have a first() aggregate function and do "select a,first(b) from t group by a".

I'm sure it's very convenient.

-- 
greg



В списке pgsql-sql по дате отправления:

Предыдущее
От: cadiolis@gmail.com
Дата:
Сообщение: Re: Text->Date conversion in a WHERE clause
Следующее
От: Yasir Malik
Дата:
Сообщение: Re: regular expression