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

 

CREATE TABLE [dbo].[NumSeq]
(
SQL存储过程生成流水号   
[Cate] [varchar] (2NOT NULL
,
SQL存储过程生成流水号   
[DateNo] [varchar] (4NOT NULL
,
SQL存储过程生成流水号   
[Seq] [int] NULL
,
SQL存储过程生成流水号   
[CrTime] [datetime] NOT NULL

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

2,创建存储过程

 

CREATE  PROC dpPMT_SGetMaintainSeq
SQL存储过程生成流水号
@MaintainCate
VARCHAR(2
)
SQL存储过程生成流水号
SQL存储过程生成流水号
AS

SQL存储过程生成流水号
--***********************累加编号*************************************************
SQL存储过程生成流水号
DECLARE
@MaintainNo VARCHAR(12
)
SQL存储过程生成流水号
IF NOT EXISTS(SELECT

SQL存储过程生成流水号           
*

SQL存储过程生成流水号       
FROM
SQL存储过程生成流水号            
NumSeq
SQL存储过程生成流水号       
WHERE
SQL存储过程生成流水号            
Cate
=@MaintainCate
AND
DATEDIFF(DAY,CrTime,GETDATE())=0
)
SQL存储过程生成流水号   
BEGIN

SQL存储过程生成流水号       
INSERT
INTO

SQL存储过程生成流水号            
NumSeq(Cate,DateNo,Seq)
SQL存储过程生成流水号       
values(@MaintainCate,RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE())),0
)
SQL存储过程生成流水号
SQL存储过程生成流水号   
END

SQL存储过程生成流水号
ELSE
SQL存储过程生成流水号   
BEGIN
SQL存储过程生成流水号       
UPDATE
SQL存储过程生成流水号            
NumSeq
SQL存储过程生成流水号       
SET
SQL存储过程生成流水号            
Seq
=Seq+1

SQL存储过程生成流水号       
WHERE
SQL存储过程生成流水号            
Cate
=@MaintainCate
AND
DateNo
=RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE
()))
SQL存储过程生成流水号   
END

SQL存储过程生成流水号
SQL存储过程生成流水号
--************************组合编号***************************************************************
SQL存储过程生成流水号
SELECT
SQL存储过程生成流水号   
@MaintainNo=Cate+DateNo+REPLICATE('0',6-LEN(Seq))+CONVERT(VARCHAR(6
),Seq)
SQL存储过程生成流水号
FROM

SQL存储过程生成流水号    
NumSeq
SQL存储过程生成流水号
WHERE
SQL存储过程生成流水号    
Cate
=@MaintainCate
AND
DateNo
=RIGHT(CONVERT(VARCHAR(4),YEAR(GETDATE())),2)+REPLICATE('0',2-LEN(MONTH(GETDATE())))+CONVERT(VARCHAR(2),MONTH(GETDATE
()))
SQL存储过程生成流水号
SQL存储过程生成流水号
SELECT @MaintainNo

这个存储过程最终输出的结果如:AA071031000001
前面两位是传入的参数,中间四位是年份的后两位和月,最后的六位为6位数字的流水号。您也可以修改上面的存储过程来生成符合您要求的流水号

相关文章: