| From: | Erik Jones <erik(at)myemma(dot)com> | 
|---|---|
| To: | Andrus <kobruleht2(at)hot(dot)ee> | 
| Cc: | pgsql-general(at)postgresql(dot)org | 
| Subject: | Re: Using duplicate foreign keys | 
| Date: | 2007-01-04 19:44:00 | 
| Message-ID: | 459D5900.4050608@myemma.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-general | 
Andrus wrote:
> I have multi-company database.
> Each company has its own chart of accounts table which are stored in each 
> company schema.
> Some account numbers are used in a common table which is stored in public 
> schema.
>
> So I need to create duplicate foreign keys like
>
> create temp table company1.chartoffaccounts ( accountnumber int primary 
> key);
> create temp table company2.chartoffaccounts ( accountnumber int primary 
> key);
>
> create temp table public.commontable ( accountnumber int,
>    FOREIGN KEY (accountnumber)   REFERENCES c1hartoffaccounts 
> (accountnumber)
>    FOREIGN KEY (accountnumber)   REFERENCES c2hartoffaccounts 
> (accountnumber) );
>
>
> Is it OK to use duplicate foreign keys ? What issues will they cause ?
>
> Andrus. 
>   
The problem I see with that is that any value of accountnumber in 
public.commontable would need to be in both company1.chartoffaccounts 
and company2.chartoffaccounts.  One key referencing two completely sets 
of data?  That sounds broken.  Can you give a more detailed example of 
how you want to use this?   Off hand, it sounds like what you may want 
is to have accountnumber as the primary key of public.commontable with 
the accountnumber columns in the schema specific tables referencing it 
instead.
-- 
erik jones <erik(at)myemma(dot)com>
software development
emma(r)
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Erik Jones | 2007-01-04 19:46:26 | Re: database design and refactoring | 
| Previous Message | Michael Glaesemann | 2007-01-04 19:34:13 | Re: database design and refactoring |