Re: BUG #16703: pg-dump fails to process recursive view definition - Mailing list pgsql-bugs

From Tom Lane
Subject Re: BUG #16703: pg-dump fails to process recursive view definition
Date
Msg-id 1477409.1604593229@sss.pgh.pa.us
Whole thread Raw
In response to Re: BUG #16703: pg-dump fails to process recursive view definition  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-bugs
Further news: I thought to myself "let's leave a self-referential view
behind in the final regression test state, so we can actually exercise
pg_dump/pg_upgrade with one".  It turns out that that's not gonna work,
at least not right away.  pg_dump dumps the view all right, but it dumps

CREATE VIEW "public"."self_referential_view" AS
 SELECT "self_referential_view"."key",
    "self_referential_view"."data"
   FROM "public"."self_referential_view";

which of course fails to load, complaining "relation
"public.self_referential_view" does not exist".

I'm not particularly desperate to do anything about that.  It's important
that pg_dump not fail on such a view, so you don't have a risk that your
backups didn't work at all.  But if you have to do some finagling to
restore it, that's less critical.  Also, this has been the situation all
along and there have been no complaints.

One could imagine getting pg_dump to handle this by treating the
self-reference as a circular reference and then doing what it does
to break reference loops with views.  I experimented briefly with
that, but it's a bigger can of worms than it seems; pg_dump_sort.c
does not seem to have quite enough info to tell whether references
are explicit self-references or not.

            regards, tom lane



pgsql-bugs by date:

Previous
From: Tom Lane
Date:
Subject: Re: BUG #16703: pg-dump fails to process recursive view definition
Next
From: "David G. Johnston"
Date:
Subject: Re: Wrong result for comparing ROW(...) with IS NOT NULL