C#流水号生成汇总(一)

分享C#原生ID(流水号)生成功能实现

本文转载:http://www.cnblogs.com/Ruiky/archive/2012/04/28/2475049.html

一、非存储过程生成的流水号

  /// <summary>
    /// 
    /// </summary>
    public static class DataBaseGenerator
    {
        /// <summary>
        /// 
        /// </summary>
        private static Int64 seed = Int64.Parse(DateTime.UtcNow.Subtract(new DateTime(1970, 1, 1)).TotalMilliseconds.ToString("0"));

        /// <summary>
        /// 
        /// </summary>
        /// <returns></returns>
        public static Int64 GetPrimaryKey()
        {
            return Interlocked.Increment(ref seed);
        }
    }
View Code
internal class Program
    {
        private static void Main(string[] args)
        {
            for (int i = 0; i < 10; i++)
            {
                Console.WriteLine(DataBaseGenerator.GetPrimaryKey().ToString());
            }

            Console.ReadKey();
        }
    }

//输出
1411804353746
1411804353747
1411804353748
1411804353749
1411804353750
View Code

二、存储过程生成流水号
1,首先在数据库中创建一个存放流水号的表

CREATE TABLE [dbo].[NumSeq](
    [Cate] [varchar](2) NOT NULL,
    [DateNo] [varchar](4) NOT NULL,
    [Seq] [int] NULL,
    [CrTime] [datetime] NOT NULL
) ON [PRIMARY]

GO

SET ANSI_PADDING OFF
GO

ALTER TABLE [dbo].[NumSeq] ADD  CONSTRAINT [DF_NumSeq_CrTime]  DEFAULT (getdate()) FOR [CrTime]
GO
View Code

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

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
View Code

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

C#流水号生成汇总(一)_第1张图片 

 

你可能感兴趣的:(C#)