Re: pg_restore with --disable-triggers discards ENABLE ALWAYS
От | Tom Lane |
---|---|
Тема | Re: pg_restore with --disable-triggers discards ENABLE ALWAYS |
Дата | |
Msg-id | 4156698.1726174027@sss.pgh.pa.us обсуждение исходный текст |
Ответ на | Re: pg_restore with --disable-triggers discards ENABLE ALWAYS (Laurenz Albe <laurenz.albe@cybertec.at>) |
Ответы |
Re: pg_restore with --disable-triggers discards ENABLE ALWAYS
Re: pg_restore with --disable-triggers discards ENABLE ALWAYS |
Список | pgsql-bugs |
Laurenz Albe <laurenz.albe@cybertec.at> writes: > On Thu, 2024-09-12 at 10:27 +0200, Duncan Sands wrote: >> pg_restore --data-only --disable-triggers --dbname duncan dump.custom >> ^ Observe that "Triggers firing always" has disappeared. > This looks like a user error to me. > If you restore with --data-only, the table and constraint definitions > are not restored at all. So the table "test_table" in database "duncan" > must already have existed before the restore, and the trigger was already > defined like that. The given recipe seems incomplete, but I think Duncan has put his finger on a shortcoming. pg_restore with --disable-triggers will issue ALTER TABLE foo DISABLE TRIGGER ALL; and later ALTER TABLE foo ENABLE TRIGGER ALL; and if you read the fine print in the ALTER TABLE man page, you'll discover that ENABLE TRIGGER sets the triggers' replication mode to the default (origin only). I'm not sure why somebody thought that replication mode shouldn't be stored separately from enable/disable, but it isn't: there's just one four-valued state field. We could probably add code to make pg_dump individually re-enable the table's triggers with the appropriate state(s), but I can't muster too much enthusiasm for writing that myself. regards, tom lane
В списке pgsql-bugs по дате отправления: