Re: FOREIGN KEY Reference on multiple columns

From: Tim Landscheidt <tim(at)tim-landscheidt(dot)de>
To: pgsql-sql(at)postgresql(dot)org
Subject: Re: FOREIGN KEY Reference on multiple columns
Date: 2014-09-24 18:02:34
Message-ID: 87y4t8rj5x.fsf@passepartout.tim-landscheidt.de
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

"Weiss, Jörg" <J(dot)Weiss(at)dvz-mv(dot)de> wrote:

> I mean b must equal to c1 in the "other_table" where c2 has a certain value (for example c2 ).

> For my first example:
> CREATE TABLE parm
> (
> complex varchar(20) NOT NULL,
> para varchar(50) NOT NULL,
> sort int4 NOT NULL DEFAULT 10,
> value varchar(50) NULL,
> CONSTRAINT parm_pkey PRIMARY KEY (complex, para, sort)
> )

> Table user
> CREATE TABLE user
> (
> name varchar(20) NOT NULL,
> type integer NULL
> )
> In this case "type" of table user must equal to "value" of table "parm" and "para" must be "login_user" (for example)

> [...]

You can achieve that by duplicating the para column to the
table user, adding a foreign key that matches both columns
to table parm and checks in table user whether para is
"login_user". That doesn't work for NULLable columns,
though.

Tim

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Weiss 2014-09-25 05:04:40 Re: FOREIGN KEY Reference on multiple columns
Previous Message Weiss 2014-09-23 13:38:32 Re: FOREIGN KEY Reference on multiple columns