From: | Stephan Szabo <sszabo(at)megazone23(dot)bigpanda(dot)com> |
---|---|
To: | Evgen Potemkin <evgent(at)ns(dot)terminal(dot)ru> |
Cc: | <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: Reference integrity question |
Date: | 2003-01-04 15:16:25 |
Message-ID: | 20030104071505.Y20289-100000@megazone23.bigpanda.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | 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.
From | Date | Subject | |
---|---|---|---|
Next Message | pginfo | 2003-01-05 09:26:35 | Deleting in order from a table |
Previous Message | Kevin Gordon | 2003-01-04 03:57:09 | SQL to determine Tablenames, Primarykeys & Foreignkeys] |