Re: BUG #17376: Adding unique column with a function() default results in "could not read block 0 in file" error

From: Japin Li <japinli(at)hotmail(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: adrien(dot)gilmore+pg(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #17376: Adding unique column with a function() default results in "could not read block 0 in file" error
Date: 2022-01-22 00:18:14
Message-ID: MEYP282MB1669B9CC5478AF0421227FA8B65C9@MEYP282MB1669.AUSP282.PROD.OUTLOOK.COM
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-bugs


On Sat, 22 Jan 2022 at 01:36, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
> Japin Li <japinli(at)hotmail(dot)com> writes:
>> On Fri, 21 Jan 2022 at 17:22, PG Bug reporting form <noreply(at)postgresql(dot)org> wrote:
>>> The error message content returned is what I suspect of being a bug, not so
>>> much that this SQL didn't work.
>
>> +1. The error message makes user confused IMO, maybe we can fix it, but I have
>> no idea for this. Any suggestion is welcomed.
>
> Yeah. Ideally we'd throw an error along the lines of "can't access a
> table that's in process of being altered". The SELECT inside the function
> is not part of the ALTER TABLE machinery and ought to be locked out.
> However, I fear we don't have adequate infrastructure to tell which
> table accesses *are* part of the ALTER TABLE machinery and which aren't.

Right.

> Maybe it'd be sufficient to check for an active ALTER TABLE in the
> parser, but I'm not sure.
>

Do you mean check the table is accessed by ALTER TABLE when calling SPI to
execute the function? How can we get the table that is be accessed by
ALTER TABLE in parser?

--
Regrads,
Japin Li.
ChengDu WenWu Information Technology Co.,Ltd.

In response to

Responses

Browse pgsql-bugs by date

  From Date Subject
Next Message Tom Lane 2022-01-22 04:15:25 Re: BUG #17376: Adding unique column with a function() default results in "could not read block 0 in file" error
Previous Message Tom Lane 2022-01-21 20:42:28 Re: Further information on BUG #17299: Exit code 3 when open connections concurrently (PQisthreadsafe() == 1)