有一段时间没有思考代码相关的工作了,最近项目经常碰到不同业务流水号的生成,下面的技术人员每次都针对流水号生成写一些复杂的代码;为了解放以后这方面的工作于是动了一下脑子想一个动态可配置的流水号生产组件,虽然没写代码一段时间但脑子在这方面还是挺灵活,大概想了一下基本就构建出一个通用业务流水号配置功能,以下分享一下这个设计。

流水号拆分

其实业务流水号都是由不同总分组成,每部分都表达不同的含意。所以在设计上需要对流水号进行分解。以"GZ201602020001RJ"的主要组成部分:{GZ}{20160202}{0001}{RJ}


  • {GZ}
    这个规则主要是描述所在城市地区
  • {20160202}
    当前业务所在的年月日
  • {0001}
    当天递增量
  • {RJ}
    固定业务类型

       总的来说,业务流水号都是由不同参数所组成。

设计

在设计上必须由一个基础的设计模型来支持不同参数的来源和扩展,可能定义一个基础的结构{Type:Parameter}。那流水号的组成规则是{Type1:Parameter}{Type2:Parameter}{Type2:Parameter},通过不同的规则拼装而成;在技术可以定义一个接口来定义一个参数的定义。

public interface IParameterHandler
{
    void Execute(StringBuilder sb, string value);
}

针对以上规则定义一个简单针对中文获取首拼音的规则:{CN:广州},针对这情况可以实现如下:

    /// <summary>
    /// {CN:广州}
    /// </summary>
    [ParameterType("CN")]
 public class ChineseSpellCodeParameter : IParameterHandler
 {
        public void Execute(StringBuilder sb, string value)
        {

            foreach (char item in value)
            {
                sb.Append(Hz2Py.Convert(item.ToString()).Substring(0, 1));
            }

        }
}


        经过参数模块解释{CN:广州}=GZ

        通过这种方式可以扩展出很多很多不同的可配置的参数规则来满足应用的需要。

整体使用效果

针对最开始的那个业务号详细定义规则如下:{CN:广州}{D:yyyyMMdd}{N:{D:yyyyMMdd}/0000}{S:RJ}

            string[] rule = new string[]{ 
                "{CN:广州}{D:yyyyMMdd}{N:{D:yyyyMMdd}/0000}{S:RJ}"
            };
            foreach (string item in rule)
            {
                string value = BNRFactory.Default.Create(item);
                Console.WriteLine(item);
                Console.WriteLine(value);
            }




关注微信公众号



相关文章