zoukankan      html  css  js  c++  java
  • 分享C#原生ID(流水号)生成功能实现

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

       /// <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);
            }
        }

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

    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位数字的流水号。您也可以修改上面的存储过程来生成符合您要求的流水号

  • 相关阅读:
    epoll的LT和ET模式
    linux搭建java环境
    【第三方SDK】百度地图实现最简单的定位功能(无地图界面)
    闲云控制台(二)查看文件功能,支持十六进制查看文件
    ios8 swift开发:显示变量的类名称
    cocos2dx的runAction: 反复运行,多个动作连接运行,多个动作同一时候运行的实现
    myeclipse设置凝视
    2-06. 数列求和(20)(ZJUPAT 数学)
    【IPC进程间通信之四】数据复制消息WM_COPYDATA
    条件熵定义推导公式
  • 原文地址:https://www.cnblogs.com/Ruiky/p/2475049.html
Copyright © 2011-2022 走看看