Обсуждение: DISTINCT MAX() results mismatch on 8.2 and 8.3

Поиск
Список
Период
Сортировка

DISTINCT MAX() results mismatch on 8.2 and 8.3

От
Taiki Yamaguchi
Дата:
Hi,


I tried DISTINCT MAX() on the 8.2 and 8.3 as below.


8.2.6
==============================
yamaguti=# create table t1 (i int, j int primary key);
NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index
"t1_pkey" for table "t1" CREATE TABLE
yamaguti=# insert into t1 select g, g from generate_series(1, 100) as g;
INSERT 0 100
yamaguti=# select distinct max(i) from t1;
 max
-----
 100
(1 row)

yamaguti=# select distinct max(j) from t1;
 max
-----
 100
(1 row)
==============================

8.3.0
==============================
yamaguti=# create table t1 (i int, j int primary key);
NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index
"t1_pkey" for table "t1" CREATE TABLE
yamaguti=# insert into t1 select g, g from generate_series(1, 100) as g;
INSERT 0 100
yamaguti=# select distinct max(i) from t1;
 max
-----
 100
(1 row)

yamaguti=# select distinct max(j) from t1;
ERROR:  could not find pathkey item to sort
==============================


If a column has a primary-key constraint, DISTINCT MAX() fails on 8.3.

I know that the DISTINCT in this query has no meanings, but I wasn't
certain that this was an intended behaviour or not (a bug). If it was a
bug, would it be fixed in the future?


Best regards,


--
Taiki Yamaguchi
<yamaguchi@sraoss.co.jp>

Re: DISTINCT MAX() results mismatch on 8.2 and 8.3

От
Tom Lane
Дата:
Taiki Yamaguchi <yamaguchi@sraoss.co.jp> writes:
> If a column has a primary-key constraint, DISTINCT MAX() fails on 8.3.

> I know that the DISTINCT in this query has no meanings, but I wasn't
> certain that this was an intended behaviour or not (a bug). If it was a
> bug, would it be fixed in the future?

It's certainly a bug and should be fixed ... I'm too tired to look into
the cause right now, though.

            regards, tom lane

Re: DISTINCT MAX() results mismatch on 8.2 and 8.3

От
Tom Lane
Дата:
Taiki Yamaguchi <yamaguchi@sraoss.co.jp> writes:
> yamaguti=# select distinct max(j) from t1;
> ERROR:  could not find pathkey item to sort

Fixed in HEAD and 8.3.  Thanks for the report!

            regards, tom lane

Re: DISTINCT MAX() results mismatch on 8.2 and 8.3

От
"Kevin Grittner"
Дата:
>>> On Wed, Mar 26, 2008 at  9:23 PM, in message
<20080327112308.b1e9a692.yamaguchi@sraoss.co.jp>, Taiki Yamaguchi
<yamaguchi@sraoss.co.jp> wrote:

> 8.3.0
> ==============================
> yamaguti=# create table t1 (i int, j int primary key);
> NOTICE:  CREATE TABLE / PRIMARY KEY will create implicit index
> "t1_pkey" for table "t1" CREATE TABLE
> yamaguti=# insert into t1 select g, g from generate_series(1, 100) as
g;
> INSERT 0 100
> yamaguti=# select distinct max(i) from t1;
>  max
> -----
>  100
> (1 row)
>
> yamaguti=# select distinct max(j) from t1;
> ERROR:  could not find pathkey item to sort
> ==============================

For the benefit of anyone searching the archives for the problem we
just hit, this message also occurs in 8.3.1 and also occurs against
the above test table for this statement:

test=# select max(j) as "maxj" from t1 order by "maxj";
ERROR:  could not find pathkey item to sort

Neither statement causes the error when run against a build from
REL8_3_STABLE from 35 minutes ago (2008-04-22 10:15 CDT).

-Kevin

Re: DISTINCT MAX() results mismatch on 8.2 and 8.3

От
Tom Lane
Дата:
"Kevin Grittner" <Kevin.Grittner@wicourts.gov> writes:
>> yamaguti=# select distinct max(j) from t1;
>> ERROR:  could not find pathkey item to sort

> For the benefit of anyone searching the archives for the problem we
> just hit, this message also occurs in 8.3.1 and also occurs against
> the above test table for this statement:

> test=# select max(j) as "maxj" from t1 order by "maxj";
> ERROR:  could not find pathkey item to sort

> Neither statement causes the error when run against a build from
> REL8_3_STABLE from 35 minutes ago (2008-04-22 10:15 CDT).

Yeah, this was repaired here:
http://archives.postgresql.org/pgsql-committers/2008-03/msg00563.php

The fix will be in 8.3.2.

            regards, tom lane