| From: | Kirill Reshke <reshkekirill(at)gmail(dot)com> | 
|---|---|
| To: | linyuzhe(dot)lyz(at)gmail(dot)com, pgsql-bugs(at)lists(dot)postgresql(dot)org | 
| Subject: | Re: BUG #18763: pg_get_viewdef returns an old def with new relation name | 
| Date: | 2025-01-04 07:14:42 | 
| Message-ID: | CALdSSPhO_XVe+iPz1+A-wrMD46Hxb-rxFpUvnGigGpZoSVbecQ@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-bugs | 
On Thu, 2 Jan 2025 at 15:19, PG Bug reporting form
<noreply(at)postgresql(dot)org> wrote:
>
> The following bug has been logged on the website:
>
> Bug reference:      18763
> Logged by:          lyz
> Email address:      linyuzhe(dot)lyz(at)gmail(dot)com
> PostgreSQL version: 13.7
> Operating system:   Linux
> Description:
>
> in first connection
>
> test5=# create table a1(c int);
> CREATE TABLE
> test5=# create table a2(c int);
> CREATE TABLE
> test5=# create view v as select * from a1;
> CREATE VIEW
>
> then rename relation names and replace view in one txn, but not commit.
>
> test5=# begin;
> BEGIN
> test5=*# alter table a1 rename to a3;
> ALTER TABLE
> test5=*# alter table a2 rename to a1;
> ALTER TABLE
> test5=*# create or replace view v as select * from a1;
> CREATE VIEW
>
> in second connection:
>
> test5=# select pg_get_viewdef('v');
>
> it will be stuck by AccessShareLock of 'v'.
>
> Then we commit txn in first connection,
> the result of second connection wii be:
>
>  pg_get_viewdef
> ----------------
>   SELECT a3.c  +
>     FROM a3;
> (1 row)
>
>  old definition but using new relation name.
>
Reproduced here on HEAD. I also reproduce this with `begin transaction
isolation level serializable;`, so this is likely not an isolation
issue...
-- 
Best regards,
Kirill Reshke
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tomas Vondra | 2025-01-04 11:43:28 | Re: BUG #18766: not exists sometimes gives too few records | 
| Previous Message | Tomas Vondra | 2025-01-03 19:01:57 | Re: BUG #18766: not exists sometimes gives too few records |