Click here to Skip to main content
Rate this: bad
good
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
good
Please Sign up or sign in to vote.

Solution 1

No.
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.
  Permalink  

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

  Print Answers RSS
0 Sergey Alexandrovich Kryukov 480
1 OriginalGriff 258
2 Bhavik_Patel 170
3 PhilLenoir 155
4 Richard Deeming 140
0 Sergey Alexandrovich Kryukov 8,688
1 OriginalGriff 7,237
2 CPallini 2,598
3 Richard MacCutchan 2,080
4 Abhinav S 1,888


Advertise | Privacy | Mobile
Web03 | 2.8.140827.1 | Last Updated 31 May 2011
Copyright © CodeProject, 1999-2014
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