Thread: Primary and Foreign Key?

Primary and Foreign Key?

From
"A. Banks"
Date:
I have the following related tables:

PEOPLE
--------------
peopleid pkey,
name,
etc


GROUPS
-------------
groupid pkey,
description,
etc


PEOPLEGROUPS
-------------------
peopleid pkey/fkey,
groupid pkey/fkey


What is the CORRECT way (in Postgres) to define the PEOPLEGROUPS table so
that it has both the double primary key AND still acts as a foreign key for
people.peopleid and groups.groupid? Can i specify both or is this not
necessary? Any suggestions would be appreciated.

Thanks!
--
No virus found in this outgoing message.
Checked by AVG Anti-Virus.
Version: 7.0.344 / Virus Database: 267.11.3/107 - Release Date: 9/20/2005


Re: Primary and Foreign Key?

From
"Wayne Unruh"
Date:
In relational databases  A table can have at most one primary key.  However,
you are not required to have a primary key, so I would just have the two
foreign keys in the table PEOPLEGROUPS.

For more information on Constraints see
http://www.postgresql.org/docs/8.0/interactive/ddl-constraints.html

Wayne Unruh

From :     A. Banks <abanks@insightbb.com>
Sent :     Wednesday, September 21, 2005 8:46 PM
To :     <pgsql-novice@postgresql.org>
Subject :     [NOVICE] Primary and Foreign Key?



I have the following related tables:

PEOPLE
--------------
peopleid pkey,
name,
etc


GROUPS
-------------
groupid pkey,
description,
etc


PEOPLEGROUPS
-------------------
peopleid pkey/fkey,
groupid pkey/fkey


What is the CORRECT way (in Postgres) to define the PEOPLEGROUPS table so
that it has both the double primary key AND still acts as a foreign key for
people.peopleid and groups.groupid? Can i specify both or is this not
necessary? Any suggestions would be appreciated.

Thanks!



Re: Primary and Foreign Key?

From
Oliver Elphick
Date:
On Wed, 2005-09-21 at 19:46 -0500, A. Banks wrote:
> I have the following related tables:
>
> PEOPLE
> --------------
> peopleid pkey,
> name,
> etc
>
>
> GROUPS
> -------------
> groupid pkey,
> description,
> etc
>
>
> PEOPLEGROUPS
> -------------------
> peopleid pkey/fkey,
> groupid pkey/fkey
>
>
> What is the CORRECT way (in Postgres) to define the PEOPLEGROUPS table so
> that it has both the double primary key AND still acts as a foreign key for
> people.peopleid and groups.groupid? Can i specify both or is this not
> necessary? Any suggestions would be appreciated.

Your terminology is a bit wrong; there can only ever be one primary key
for a table; what you want is probably a single primary key made up of
two columns.

Your definition will look like this:

CREATE TABLE people (
   peopleid    SERIAL PRIMARY KEY,  -- SERIAL is an INTEGER that autoincrements
                                     -- if no value is supplied on insertion
   name        TEXT NOT NULL,
   ...
);

CREATE TABLE groups (
   groupid    SERIAL PRIMARY KEY,
   name        TEXT NOT NULL,
   ...
);

CREATE TABLE peoplegroups (
   peopleid    INTEGER
                REFERENCES people (peopleid)
                   ON UPDATE CASCADE ON DELETE NO ACTION,
   groupid    INTEGER
                REFERENCES people (peopleid)
                   ON UPDATE CASCADE ON DELETE NO ACTION,
   PRIMARY KEY (peopleid, groupid)
);
--
Oliver Elphick                                          olly@lfix.co.uk
Isle of Wight                              http://www.lfix.co.uk/oliver
GPG: 1024D/A54310EA  92C8 39E7 280E 3631 3F0E  1EC0 5664 7A2F A543 10EA
                 ========================================
   Do you want to know God?   http://www.lfix.co.uk/knowing_god.html


Re: Primary and Foreign Key?

From
"Announce"
Date:
I think i found what i was looking for in the docs:

5.3.4. Primary Keys
Technically, a primary key constraint is simply a combination of a unique
constraint and a not-null constraint.

So i suppose i suppose i would use PRIKARY KEY(peopleid,groupid) to enforce
the UNIQUE NOT NULL constraint in one expression.

Thanks!
-----Original Message-----
From: Wayne Unruh [mailto:waynepunruh@hotmail.com]
Sent: Saturday, September 24, 2005 1:46 AM
To: abanks@insightbb.com; pgsql-novice@postgresql.org
Subject: RE: [NOVICE] Primary and Foreign Key?


In relational databases  A table can have at most one primary key.  However,
you are not required to have a primary key, so I would just have the two
foreign keys in the table PEOPLEGROUPS.

For more information on Constraints see
http://www.postgresql.org/docs/8.0/interactive/ddl-constraints.html

Wayne Unruh

From :     A. Banks <abanks@insightbb.com>
Sent :     Wednesday, September 21, 2005 8:46 PM
To :     <pgsql-novice@postgresql.org>
Subject :     [NOVICE] Primary and Foreign Key?



I have the following related tables:

PEOPLE
--------------
peopleid pkey,
name,
etc


GROUPS
-------------
groupid pkey,
description,
etc


PEOPLEGROUPS
-------------------
peopleid pkey/fkey,
groupid pkey/fkey


What is the CORRECT way (in Postgres) to define the PEOPLEGROUPS table so
that it has both the double primary key AND still acts as a foreign key for
people.peopleid and groups.groupid? Can i specify both or is this not
necessary? Any suggestions would be appreciated.

Thanks!




--
No virus found in this incoming message.
Checked by AVG Anti-Virus.
Version: 7.0.344 / Virus Database: 267.11.5/110 - Release Date: 9/22/2005


--
No virus found in this incoming message.
Checked by AVG Anti-Virus.
Version: 7.0.344 / Virus Database: 267.11.5/110 - Release Date: 9/22/2005