Re: foreign keys and lots of tables - Mailing list pgsql-sql

From David W Noon
Subject Re: foreign keys and lots of tables
Date
Msg-id 20110519010907.770c8c48@karnak.local
Whole thread Raw
In response to foreign keys and lots of tables  (Gary Stainburn <gary.stainburn@ringways.co.uk>)
Responses Re: SOLVED - foreign keys and lots of tables  (Gary Stainburn <gary.stainburn@ringways.co.uk>)
List pgsql-sql
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.
--
Regards,

Dave  [RLU #314465]
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
dwnoon@ntlworld.com (David W Noon)
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*

pgsql-sql by date:

Previous
From: Eric McKeeth
Date:
Subject: Re: column type for pdf file
Next
From: Craig Ringer
Date:
Subject: Re: client-side lo_import() provided by libpq ?