ぷ行走de猫げ

在快乐中成长,在快乐中学习!

SQL存储过程生成流水号

首先在数据库中创建一个存放流水号的表

 

CREATE TABLE [dbo].[NumSeq]
(
   
[Cate] [varchar] (2NOT NULL
,
   
[DateNo] [varchar] (4NOT 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位数字的流水号。您也可以修改上面的存储过程来生成符合您要求的流水号
posted @   李天翔  阅读(2534)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏