如何在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
在TableA中,我有一个int列.
是否可以仅使用select语句来选择不存在且大于0的列中的最小值?
例如,如果col的值为1,2,9,则select语句将返回3.如果col具有9,10,11,则返回1.
我可以使用临时表或使用循环来实现这一点,但我想知道我是否可以使用select语句来完成它?
谢谢.