Re: Alter or rename enum value

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Alter or rename enum value
Дата
Msg-id 4075.1459088427@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: Alter or rename enum value  (Andrew Dunstan <andrew@dunslane.net>)
Ответы 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>)
Список 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 по дате отправления:

Предыдущее
От: Alexander Korotkov
Дата:
Сообщение: Re: Move PinBuffer and UnpinBuffer to atomics
Следующее
От: Tom Lane
Дата:
Сообщение: Re: AssertArg failure in src/backend/executor/functions.c:check_sql_fn_retval()