Re: Reference integrity question

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.

Browse pgsql-sql by date

  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]