Re: BUG #15865: ALTER TABLE statements causing "relation already exists" errors when some indexes exist - Mailing list pgsql-bugs

From Tom Lane
Subject Re: BUG #15865: ALTER TABLE statements causing "relation already exists" errors when some indexes exist
Date
Msg-id 21081.1561135675@sss.pgh.pa.us
Whole thread Raw
In response to Re: BUG #15865: ALTER TABLE statements causing "relation already exists" errors when some indexes exist  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-bugs
I wrote:
> BTW, has anyone got an explanation for the order in which psql is
> listing the indexes of "anothertab" in this test case?

Ah, here's the explanation: describe.c is sorting the indexes
with this:

    "ORDER BY i.indisprimary DESC, i.indisunique DESC, c2.relname;"

I can see the point of putting the pkey first, I guess, but the preference
for uniques second seems pretty bizarre, especially since
(a) it doesn't distinguish unique constraints from plain unique indexes and
(b) there's no similar preference for exclusion constraints, even though
those might be morally equivalent to a unique constraint.

What do people think of dropping the indisunique sort column here?
Obviously not back-patch material, but it might be more sensible
behavior going forward.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #15865: ALTER TABLE statements causing "relation already exists" errors when some indexes exist
Next
From: Keith Fiske
Date:
Subject: Re: BUG #15865: ALTER TABLE statements causing "relation alreadyexists" errors when some indexes exist