如何在SQL Server列中找到最小的未使用数字?
我将要将大量手动记录的记录从Excel导入SQL Server表.它们都有一个数字ID(称为文档编号),但由于不再适用的原因,它们没有按顺序分配,这意味着从现在开始我的网站记录新记录时,需要为其分配最小的文档编号(尚未采取的大于零).
有没有办法通过纯SQL执行此操作,或者这是TSQL /代码的问题?
谢谢!
编辑
特别感谢WW提出并发问题.鉴于这是一个Web应用程序,它根据定义是多线程的,任何面临同样问题的人都应该考虑代码或数据库级别锁定来防止冲突.
LINQ
仅供参考 - 这可以通过LINQ使用以下代码完成:
var nums = new [] { 1,2,3,4,6,7,9,10};
int nextNewNum = (
from n in nums
where !nums.Select(nu => nu).Contains(n + 1)
orderby n
select n + 1
).First();
Run Code Online (Sandbox Code Playgroud)
nextNewNum == 5