Re: Reference integrity question - Mailing list pgsql-sql

From Stephan Szabo
Subject Re: Reference integrity question
Date
Msg-id 20030104071505.Y20289-100000@megazone23.bigpanda.com
Whole thread Raw
In response to Reference integrity question  (Evgen Potemkin <evgent@ns.terminal.ru>)
List pgsql-sql
On Sat, 4 Jan 2003, Evgen Potemkin wrote:

> > > I have two tables
> > >   news(newsid int4, newscltid int4 references clt(cltid) match full,newstext text)
> > > and
> > >   clt(cltid int4, somedata text).
> > > after clt is renamed , for ex. to clt_old, newscltid start to reference to clt_old.cltid.
> > >   i'm create new table clt(cltid int4, anotherdata text);
> > >
> > > is there any way to make newscltid reference to newly created clt, beside
> > > recreation of news ?
> >
> > If you mean that all newscltids should reference the new table (presumably
> > already loaded)...
> >
> > Since you haven't given a version, let's guess 7.3, in which case the
> > constraint should probably be named "$1" and you can do an
> > ALTER TABLE news drop constraint "$1";
> > ALTER TABLE news add foreign key (newscltid) references clt(cltid) match
> > full;
> >
> v 7.3, but i'm upgraded from 7.2
> \d news
> shows that there is no constraints, but constraint triggers a la
> RI_ConstraintTrigger_262762.
> when i'm dumps schema, first of trigger func parameters is '<unnamed>', so i
> guess it's a contraint name.

In that case you'll need to drop the triggers manually (there are three
triggers, one on the fk table and two on the pw table) and add the
constraint using ALTER TABLE.  For info on the triggers, there's a couple
of documents on techdocs.




pgsql-sql by date:

Previous
From: Kevin Gordon
Date:
Subject: SQL to determine Tablenames, Primarykeys & Foreignkeys]
Next
From: pginfo
Date:
Subject: Deleting in order from a table