sql server新增数据时主键自动生成
生成规则为四位年份+二位月份+三位流水号
如:201812001、201812002
这个应该怎么解决,目前思路是写函数,函数应该怎么写,求各位大神帮忙
sql server新增数据时主键自动生成
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
xinboyXu 2018-12-06 03:46关注create function getTestUID()
returns VARCHAR(10)
as
BEGIN
DECLARE @UID VARCHAR(10)
DECLARE @UYEARMOTHN VARCHAR(6)
DECLARE @MaxId VARCHAR(10)
DECLARE @SORE INT
set @UYEARMOTHN = CONVERT(varchar(6),GETDATE(),112) --如果不想取当前年月的话,根据你的情况 直接赋值为 201802
select @MaxId = isnull(max(uId),0) from test222 -- 注意改成自己的表名
IF (@MaxId=0 )
BEGIN
SET @UID = @UYEARMOTHN+'001' --建议流水号设大些吧, 下面的判断相应的改
END
ELSE
BEGIN
SET @SORE = Convert(int,RIGHT(@MaxId,3))
IF(@SORE>=99)
BEGIN
set @UID = @UYEARMOTHN + convert(VARCHAR,(@SORE+1))
END
ELSE IF(@SORE>=9)
BEGIN
set @UID = @UYEARMOTHN + '0'+convert(VARCHAR,(@SORE+1))
END
ELSE IF(@SORE>0)
BEGIN
set @UID = @UYEARMOTHN + '00'+convert(VARCHAR,(@SORE+1))
END
ENDRETURN @UIDEND
select dbo.getTestUID()
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决评论 打赏 举报无用 1