Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Database table structure

Posted on 2013-05-20
3
Medium Priority
?
330 Views
Last Modified: 2013-05-20
One table "COMPANIES" needs to be linked to another table "CONTACTS".  Here is the twist: the contact for each company will change over time, but we need to keep the contacts.  My initial solution was to create a join table named something like "ACTIVE_CONTACT" that would hold pairs of the Company ID and the Contact ID, but i didn't know how to prevent a duplicate Company ID from being entered in the "ACTIVE_CONTACT" table. How would I do that?

Or, maybe using a join table is not the way to go?
0
Comment
Question by:rrhandle8
  • 2
3 Comments
 
LVL 29

Accepted Solution

by:
Paul Jackson earned 2000 total points
ID: 39182896
A join table is the way to go. If you need to keep previous company contacts I would have a join table as you have described but rather than calling it active_contact just call it company_contacts and as well as the Company Id and Contact Id have another column called Active and make it a bit datatype which would be set for active contact records. You would make the Primary Key of this table a joint key of the Company Id and the Contact Id
Doing it this way means you would have a history of company contacts and the active contacts.

Alternatively if you felt that there was no need to keep a history of the contacts for each company in the company_contacts table you would just use Columns of Company ID and Contact ID and make them a company id the primary key for the join table to prevent duplicate contacts for a company. Obviously you will need logic in your stored procedures or business logic to delete a current active contact for a company when another is added.
0
 

Author Comment

by:rrhandle8
ID: 39182989
I've requested that this question be deleted for the following reason:

I decide to make the Company ID column unique.  
0
 

Author Closing Comment

by:rrhandle8
ID: 39182990
Jacko72,  I did not see your answer when I tried to delete the question.  I am awarding you now.  Thank you.
0

Featured Post

Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

It is possible to export the data of a SQL Table in SSMS and generate INSERT statements. It's neatly tucked away in the generate scripts option of a database.
This month, Experts Exchange sat down with resident SQL expert, Jim Horn, for an in-depth look into the makings of a successful career in SQL.
Familiarize people with the process of utilizing SQL Server functions from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Ac…
Using examples as well as descriptions, and references to Books Online, show the documentation available for datatypes, explain the available data types and show how data can be passed into and out of variables.

885 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question