Solved

Sql server Identity usage

Posted on 2014-03-31
1
172 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
1 Comment
 
LVL 24

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

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

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 …
What my article will show is if you ever had to do processing to a listbox without being able to just select all the items in it. My software Visual Studio 2008 crystal report v11 My issue was I wanted to add crystal report to a form and show…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
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…

758 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

Need Help in Real-Time?

Connect with top rated Experts

21 Experts available now in Live!

Get 1:1 Help Now