Click here to Skip to main content
11,503,113 members (75,379 online)
Rate this: bad
Please Sign up or sign in to vote.
See more: SQL-server-2005
My table values are follows.

Id(pk) Item
1 Laptop
2 Pendrive
5 Mouse
When I insert a new item to the table, it should assign a No.3 as ID (ie.Miimum Number available).

Is there any way in the sql-server2005 to auto-assign the pk-field with minimum available number.
Now I am doing it programatically (in the button click event read all the ID from the table and computing this ID prgramatically and inserting new item with this ID.)
This may cause cuncurrency because there is gap for computation between fetching the value and inserting new item with this value
Posted 31-May-11 5:40am

1 solution

Rate this: bad
Please Sign up or sign in to vote.

Solution 1

SQL server will always assign sequential numbers and will not automatically go back to "fill in the gaps".
The reasoning for this is that if you have other tables which referred to that ID previously, it is better to have them "hanging" with nothing to reference than to be automatically associated with a new record when it is created.

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Advertise | Privacy | Mobile
Web03 | 2.8.150520.1 | Last Updated 31 May 2011
Copyright © CodeProject, 1999-2015
All Rights Reserved. Terms of Service
Layout: fixed | fluid

CodeProject, 503-250 Ferrand Drive Toronto Ontario, M3C 3G8 Canada +1 416-849-8900 x 100