SQL存储过程生成流水号

首先在数据库中创建一个存放流水号的表
CREATE TABLE [dbo].[NumSeq] (
    
[Cate] [varchar] (2)  NOT NULL
,
    
[DateNo] [varchar] (4)  NOT NULL
,
    
[Seq] [int] NULL
,
    
[CrTime] [datetime] NOT NULL

)
上面的代码中,Cate 字段为流水号的头,可以在下面的存储过程中用参数的方式传入,我的定义是2个字符,这个可以根据具体需要更改
             DateNo 字段为获取日期信息
             Seq 字段为流水号,但最终生成的流水号是这三个字段的相加

2,创建存储过程
CREATE  PROC dpPMT_SGetMaintainSeq
@MaintainCate VARCHAR(2
)

AS

--***********************累加编号*************************************************
DECLARE @MaintainNo VARCHAR(12 )
IF NOT EXISTS(SELECT

            
*

        
FROM
             NumSeq
        
WHERE
             Cate
=@MaintainCate AND DATEDIFF(DAY,CrTime,GETDATE())=0 )
    
BEGIN

        
INSERT INTO
             NumSeq(Cate,DateNo,Seq)
        
values(@MaintainCate,RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE())),0
)

    
END

ELSE
    
BEGIN
        
UPDATE
             NumSeq
        
SET
             Seq
=Seq+1

        
WHERE
             Cate
=@MaintainCate AND DateNo=RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE ()))
    
END


--************************组合编号***************************************************************
SELECT
    
@MaintainNo=Cate+DateNo+REPLICATE('0',6-LEN(Seq))+CONVERT(VARCHAR(6
),Seq)
FROM

     NumSeq
WHERE
     Cate
=@MaintainCate AND DateNo=RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE ()))

SELECT @MaintainNo

这个存储过程最终输出的结果如:AA071031000001 前面两位是传入的参数,中间四位是年份的后两位和月,最后的六位为6位数字的流水号。您也可以修改上面的存储过程来生成符合您要求的流水号
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值