Re: Alter or rename enum value - Mailing list pgsql-hackers

From Tom Lane
Subject Re: Alter or rename enum value
Date
Msg-id 4075.1459088427@sss.pgh.pa.us
Whole thread Raw
In response to Re: Alter or rename enum value  (Andrew Dunstan <andrew@dunslane.net>)
Responses Re: Alter or rename enum value  (Christophe Pettus <xof@thebuild.com>)
Re: Alter or rename enum value  (Emre Hasegeli <emre@hasegeli.com>)
Re: Alter or rename enum value  (Andrew Dunstan <andrew@dunslane.net>)
Re: Alter or rename enum value  (Tom Dunstan <pgsql@tomd.cc>)
List pgsql-hackers
Andrew Dunstan <andrew@dunslane.net> writes:
> The more I think about this the more I bump up against the fact that 
> almost anything we do might want to do to ameliorate the situation is 
> going to be rolled back. The only approach I can think of that doesn't 
> suffer from this is to abort if an insert/update will affect an index on 
> a modified enum. i.e. we prevent the possible corruption from happening 
> in the first place, as we do now, but in a much more fine grained way.

Perhaps, instead of forbidding ALTER ENUM ADD in a transaction, we could
allow that, but not allow the new value to be *used* until it's committed?
This could be checked cheaply during enum value lookup (ie, is xmin of the
pg_enum row committed).

What you really need is to prevent the new value from being inserted
into any indexes, but checking that directly seems far more difficult,
ugly, and expensive than the above.

I do not know whether this would be a meaningful improvement for
common use-cases, though.  (It'd help if people were more specific
about the use-cases they need to work.)
        regards, tom lane



pgsql-hackers by date:

Previous
From: Alexander Korotkov
Date:
Subject: Re: Move PinBuffer and UnpinBuffer to atomics
Next
From: Tom Lane
Date:
Subject: Re: AssertArg failure in src/backend/executor/functions.c:check_sql_fn_retval()