SQL 数据库中如何自动生成订单号

有一张表TAB1,字段num。num里有很多数字,我想从1开始,查到里面缺少的最小的一个数字:例如 4,5,6,8,9,11,12,13;这样的话我想要的结果是1;1,2,3,4,5这样的话,我想要的结果是6;


其实利用正常排序的找第一个不正常递增的号码就行了,然后找出它的序号,用正常数值中最大值+1比它小的其实就行了。

create table TAB1(num varchar(32));
insert into TAB1 values(4);
insert into TAB1 values(5);
insert into TAB1 values(6);
insert into TAB1 values(8);
insert into TAB1 values(9);
insert into TAB1 values(11);
insert into TAB1 values(12);
insert into TAB1 values(13);
insert into TAB1 values(1);
insert into TAB1 values(4);


select MAX(num)+1 from TAB1  
where num <(select MIN(num) as minbreak 
            from(select num,ROW_NUMBER() over(order by num) as sort  
                 from (select distinct num from TAB1) temp1) temp2 

                 where num <> sort); 


SELECT coalesce (min (num1), count (1) + 1) FROM TAB1   --如果正好是顺序排列,找出缺少的最后一个值 
    LEFT JOIN ( 
        (SELECT min (row_num) AS num1                    --找出缺少的值 
                FROM (SELECT num  
                          , row_NUMBER () over (ORDER BY num ASC) AS row_num 
                      FROM TAB1) T1 
                WHERE t1.num != t1.row_num) 
         ) T2 ON 1 = 1 ;        


都可以。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值