DISTINCT MAX() results mismatch on 8.2 and 8.3
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>
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
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
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
"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