PostgreSQL 8.3.8 on Gentoo Linux.
I've got a junction table:
CREATE TABLE participants ( person_fk INTEGER REFERENCES persons (person_id), event_fk INTEGER REFERENCES events
(event_id)ON DELETE CASCADE, sort_order INTEGER NOT NULL DEFAULT 1, is_principal BOOLEAN NOT NULL DEFAULT TRUE,
PRIMARYKEY (person_fk, event_fk)
);
CREATE INDEX event_key ON participants (event_fk);
CREATE INDEX person_key ON participants (person_fk);
Now I want to add some text to a few participants, but as this will probably
only be for a few per cent, I try to create an extra table like this:
pgslekt=> CREATE TABLE participant_notes (
pgslekt(> person_fk INTEGER NOT NULL REFERENCES participants
(person_fk),
pgslekt(> event_fk INTEGER NOT NULL REFERENCES participants (event_fk)
ON DELETE CASCADE,
pgslekt(> part_note TEXT,
pgslekt(> PRIMARY KEY (person_fk, event_fk)
pgslekt(> );
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index
"participant_notes_pkey" for table "participant_notes"
ERROR: there is no unique constraint matching given keys for referenced table
"participants"
I fail to see what is the problem. I even tried to add a unique constraint to
participants:
pgslekt=> alter table participants add constraint unique_person_event unique
(person_fk, event_fk);
NOTICE: ALTER TABLE / ADD UNIQUE will create implicit index
"unique_person_event" for table "participants"
ALTER TABLE
But I still get the same error message as above.
This works fine, naturally:
pgslekt=> CREATE TABLE participant_notes (
pgslekt(> person_fk INTEGER NOT NULL references persons (person_id),
pgslekt(> event_fk INTEGER NOT NULL references events (event_id) ON
DELETE CASCADE,
pgslekt(> part_note TEXT,
pgslekt(> PRIMARY KEY (person_fk, event_fk)
pgslekt(> );
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index
"participant_notes_pkey" for table "participant_notes"
CREATE TABLE
However, I think that this table should reference participants, not the
primary tables persons and events.
--
Leif Biberg Kristensen
http://solumslekt.org