Solved

Sql server Identity usage

Posted on 2014-03-31
1
178 Views
Last Modified: 2014-04-02
Can I make an Identity column in a table a primary key plus make its associated tables have a primary key/Foreign that is an identity also?
If so, can I cascade delete or cascade update on an identity column?
0
Comment
Question by:metro156
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
1 Comment
 
LVL 25

Accepted Solution

by:
chaau earned 500 total points
ID: 39968404
In short: Yes for all (except for #2 - see below).

In details:
1. You can make the identity column a primary key. Make sure that it has a property to not allow NULLS

2. You create a columns in associated tables with their own primary keys. The primary key in the associated table can be an identity column. However, I do not believe you should make it a foreign key to your main table, because in this case the associated table will be in a one-to-one relationship to your main table. Imagine this simple schema:

Table Patient:
PatientID INT NOT NULL IDENTITY(1,1) PRIMARY KEY
Name Varchar(100)
Address Varchar(100)

Table PatientPhones
PhoneID INT NOT NULL IDENTITY(1,1) PRIMARY KEY
PatientID INT
Phone Varchar(20)
Type CHAR(1)

If a patient has many phones (Home, Mobile, Work, etc) you can just add more records to the PatientPhones table. The PhoneID key in this table will ensure uniqueness. The foreign key should only include the PatientID. You can make it cascading.

3. You can make the column cascading. However, please note that if you want to update an IDENTITY column in your main table you need to jump a few hoops. In short, you need to use set identity_insert Patient ON statement. But it is a question out of scope of your questions. Please let me know if you want to explore this
0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

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

This article describes how to add a user-defined command button to the Windows 7 Explorer toolbar.  In the previous article (http://www.experts-exchange.com/A_2172.html), we saw how to put the Delete button back there where it belongs.  "Delete" is …
Entering time in Microsoft Access can be difficult. An input mask often bothers users more than helping them and won't catch all typing errors. This article shows how to create a textbox for 24-hour time input with full validation politely catching …
This is Part 3 in a 3-part series on Experts Exchange to discuss error handling in VBA code written for Excel. Part 1 of this series discussed basic error handling code using VBA. http://www.experts-exchange.com/videos/1478/Excel-Error-Handlin…
In this brief tutorial Pawel from AdRem Software explains how you can quickly find out which services are running on your network, or what are the IP addresses of servers responsible for each service. Software used is freeware NetCrunch Tools (https…

726 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