Re: SOLVED - foreign keys and lots of tables

From: Gary Stainburn <gary(dot)stainburn(at)ringways(dot)co(dot)uk>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: SOLVED - foreign keys and lots of tables
Date: 2011-05-19 08:38:47
Message-ID: 201105190938.47857.gary.stainburn@ringways.co.uk
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Thanks Dave,

I came up with the same answer after much googling. I managed to write a
trigger to do this and it worked first time :D

Then I realised I was going to have to write more triggers to handle the
reverse side, i.e. deleting a coach_train record after a booking has been
made.

Thanks anyway.

Gary

On Thursday 19 May 2011 01:09:07 David W Noon wrote:
> On Wed, 18 May 2011 20:10:19 +0100, Gary Stainburn wrote about [SQL]
>
> foreign keys and lots of tables:
> >I have the following tables (individual seat allocation removed to
> >make it simpler)
>
> Omitting details makes the problem more difficult to comprehend.
>
> [snip]
>
> >create table booking_seats (
> > b_id int4 not null references bookings(b_id),
> > c_id int4, -- carriage ID
> > c_seat varchar(10) -- seat label
> >);
> >
> >The following ensures the seat exists on the coach. (not shown)
> >
> >alter table booking_seats add constraint seat_exists
> > foreign key (c_id, c_seat) references coach_seats (c_id,c_seat);
> >
> >How would I ensure that the coach exists on the train. I would need to
> >convert the b_id to a t_id using the bookings table and I don't know
> >how.
>
> I think you will need to write a trigger procedure with something like
> the following query inside it:
>
> IF NOT EXISTS(SELECT * FROM train_coaches AS tc
> INNER JOIN bookings AS b ON b.t_id = tc.t_id
> WHERE b.b_id = NEW.b_id AND tc.c_id = NEW.c_id)) THEN
> -- Something is wrong.
>
> You cannot use a subquery in a CHECK constraint, so I think a trigger
> will be the go.
>
> >To complicate things, when the initial booking is made, bot c_id and
> >c_seat are NULL. Will this make any difference?
>
> If c_id is NULL you cannot check anything against it, so your data
> integrity has just gone for a Burton.

--
Gary Stainburn
Group I.T. Manager
Ringways Garages
http://www.ringways.co.uk

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message Emi Lu 2011-05-19 13:39:54 Re: column type for pdf file
Previous Message Piotr Czekalski 2011-05-19 06:00:11 Re: column type for pdf file