Re: Error on failed COMMIT

Поиск
Список
Период
Сортировка
От Dave Cramer
Тема Re: Error on failed COMMIT
Дата
Msg-id CADK3HHL=GmVPrkypE3n03ywoJ4=jpoZ8dSPf7b-OXVRM_bbpew@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Error on failed COMMIT  (Vik Fearing <vik@postgresfriends.org>)
Ответы Re: Error on failed COMMIT
Список pgsql-hackers


On Wed, 26 Feb 2020 at 13:46, Vik Fearing <vik@postgresfriends.org> wrote:
On 25/02/2020 12:11, Laurenz Albe wrote:
> On Tue, 2020-02-25 at 13:25 +0530, Robert Haas wrote:
>> On Tue, Feb 25, 2020 at 12:47 PM Vladimir Sitnikov
>> <sitnikov.vladimir@gmail.com> wrote:
>>> Noone suggested that "commit leaves the session in a transaction state".
>>> Of course, every commit should terminate the transaction.
>>> However, if a commit fails (for any reason), it should produce the relevant ERROR that explains what went wrong rather than silently doing a rollback.
>>
>> OK, I guess I misinterpreted the proposal. That would be much less
>> problematic -- any driver or application that can't handle ERROR in
>> response to an attempted COMMIT would be broken already.
>
> I agree with that.
>
> There is always some chance that someone relies on COMMIT not
> throwing an error when it rolls back, but I think that throwing an
> error is actually less astonishing than *not* throwing one.
>
> So, +1 for the proposal from me.

I started this thread for some discussion and hopefully a documentation
patch.  But now I have moved firmly into the +1 camp.  COMMIT should
error if it can't commit, and then terminate the (aborted) transaction.
--
Vik Fearing

OK, here is a patch that actually doesn't leave the transaction in a failed state but emits the error and rolls back the transaction.

This is far from complete as it fails a number of tests  and does not cover all of the possible paths. 
But I'd like to know if this is strategy will be acceptable ?
What it does is create another server error level that will emit the error and return as opposed to not returning.
I honestly haven't given much thought to the error message. At this point I just want the nod as to how to do it.

 
Вложения

В списке pgsql-hackers по дате отправления:

Предыдущее
От: Alexey Kondratov
Дата:
Сообщение: Re: [Patch] pg_rewind: options to use restore_command fromrecovery.conf or command line
Следующее
От: legrand legrand
Дата:
Сообщение: Re: WIP: Aggregation push-down