sql中自动生成ID编号

表:

create table users
(
 id nvarchar(50),
 name nvarchar(50)
)

存储过程:

alter PROCEDURE  ListIdBuild
(
 @action  INT    = 1,   -- 类型 如1是生成一种编号,2是生成另一种编号
 @lstId   NVARCHAR(50) = NULL OUTPUT
)
AS
DECLARE
 @prefix  NVARCHAR(9),
 @maxId   INT,
 @lstPre  NVARCHAR(2)
BEGIN
 SET @prefix =  CONVERT(nchar(6), GETDATE(), 12)
 IF @action  = 1   --类型
 BEGIN
  SELECT @lstId = MAX([Id]) FROM    users    WHERE SUBSTRING([Id], 2, 2) = LEFT(@prefix, 2)
  SET @lstPre = 'U'
 END
       
 IF @lstId IS NULL SET @lstId = '00000'
 SET @lstId = RIGHT(@lstId, 5)
 SET @maxId = CAST (@lstId AS int) + 1
 SET @lstId = CONVERT(NVARCHAR(12),  @maxId)
 SET @lstId = RIGHT('000000' + @lstId, 5)
 SET @lstId = @lstPre+ @prefix + @lstId
END

 

调用:

declare @id nvarchar(50)
exec ListIdBuild 1,@id out
print @id

得到 以字母 "U"  为前缀后面跟日期的ID号 如:U07101100001

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值