Click here to Skip to main content
11,577,240 members (59,657 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)

  Print Answers RSS
0 DamithSL 155
1 Afzaal Ahmad Zeeshan 125
2 OriginalGriff 115
3 Richard MacCutchan 100
4 Abhinav S 90
0 OriginalGriff 820
1 Sergey Alexandrovich Kryukov 676
2 Abhinav S 528
3 F-ES Sitecore 420
4 Suvendu Shekhar Giri 375

Advertise | Privacy | Mobile
Web03 | 2.8.150603.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