diff options
author | Bruce Momjian <bruce@momjian.us> | 2003-01-08 22:54:06 +0000 |
---|---|---|
committer | Bruce Momjian <bruce@momjian.us> | 2003-01-08 22:54:06 +0000 |
commit | d31b20af693dfc3bc483d1e1680dbc5ce4348c18 (patch) | |
tree | 39f70f369af21224eb8ae515f3c0c7a2c97290d8 /src/backend/utils/adt/ruleutils.c | |
parent | 5e36cbe6ee56f10ded66af59919c9a1cae6b0d80 (diff) | |
download | postgresql-d31b20af693dfc3bc483d1e1680dbc5ce4348c18.tar.gz postgresql-d31b20af693dfc3bc483d1e1680dbc5ce4348c18.zip |
Fix dumping of DEFERRABLE/INITIALLY DEFERRED:
> The big problem is that while pg_dump's dump_trigger() looks at
> tginitdeferred and dumps accordingly, pg_get_constraintdef doesn't look
> at tginitdeferred, and therefore doesn't record the requirement as part
> of ALTER TABLE ADD CONSTRAINT.
pg_get_constraintdef should probably be looking at condeferrable and
condeferred in the pg_constraint row it's looking at. Maybe something
like the attached.
(Added, output only non-default values.)
Stephan Szabo
Diffstat (limited to 'src/backend/utils/adt/ruleutils.c')
-rw-r--r-- | src/backend/utils/adt/ruleutils.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/backend/utils/adt/ruleutils.c b/src/backend/utils/adt/ruleutils.c index 2fecab9655c..0275d8424ac 100644 --- a/src/backend/utils/adt/ruleutils.c +++ b/src/backend/utils/adt/ruleutils.c @@ -3,7 +3,7 @@ * back to source text * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/utils/adt/ruleutils.c,v 1.129 2002/12/14 00:17:59 tgl Exp $ + * $Header: /cvsroot/pgsql/src/backend/utils/adt/ruleutils.c,v 1.130 2003/01/08 22:54:06 momjian Exp $ * * This software is copyrighted by Jan Wieck - Hamburg. * @@ -688,6 +688,11 @@ pg_get_constraintdef(PG_FUNCTION_ARGS) } appendStringInfo(&buf, " ON DELETE %s", string); + if (conForm->condeferrable) + appendStringInfo(&buf, " DEFERRABLE"); + if (conForm->condeferred) + appendStringInfo(&buf, " INITIALLY DEFERRED"); + break; } |