Rafy 框架又添新成员:流水号插件。本文将解释 Rafy 框架中的流水插件的场景、使用方法。
场景
在开发各类数据库应用系统时,往往需要生成从一开始的流水号,有时还需要按月或者按日进行独立生成,如下面的格式:2016031800000001、2016031800000002……。
设计本插件用于生成上述相应格式的编号。
使用方法
添加插件
1.通过 Nuget Package Manager 搜索并安装 Rafy.SerialNumber 插件。
2.在 DomainApp 中添加该插件;同时,设置该插件所对应的数据库配置名:
class JXCApp : DomainApp { protected override void InitEnvironment() { //配置插件所对应的数据库配置名。 Rafy.SerialNumber.SerialNumberPlugin.DbSettingName = "TestDb"; //添加流水号插件到 Rafy 应用程序集中。 RafyEnvironment.DomainPlugins.Add(new Rafy.SerialNumber.SerialNumberPlugin()); base.InitEnvironment(); } }
使用插件
1.生成数据库。
该插件中自带两个实体:SerialNumberInfo 、SerialNumberValue ,所以 Rafy 会为其在数据库中添加相应的两张表。
2.添加流水号生成规则。
SerialNumberInfo 表示定义的流水号生成规则信息。而 SerialNumberValue 则表示生成的流水号的具体值。所以要生成流水号,必须先为其定义生成规则。可以使用 SerialNumberController 进行简单的每日规则创建,示例如下:
var controller = DomainControllerFactory.Create<SerialNumberController>();
var sni = controller.CreateDailySerialNumberInfo("流水号规则-1");
CreateDailySerialNumberInfo 方法内部其实非常简单,开发者可以参考以下代码创建新的生成规则,如下:
/// <summary> /// 创建一个以日期进行分组生成编号的规则,存储到仓库中,并返回。 /// 性能-仓库访问次数:1。 /// </summary> /// <param name="name"></param> /// <returns></returns> public SerialNumberInfo CreateDailySerialNumberInfo(string name, string format = "yyyyMMdd********") { var sni = new SerialNumberInfo { Name = name, TimeGroupFormat = "yyyyMMdd", Format = format, RollValueStart = 1, RollValueStep = 1, }; var infoRepo = RF.Concrete<SerialNumberInfoRepository>(); infoRepo.Save(sni); return sni; });
3.生成流水号。
使用以下代码生成流水号即可:
var next = controller.GenerateNext("流水号规则-1"); Assert.AreEqual("2016031800000001", next); next = controller.GenerateNext("流水号规则-1"); Assert.AreEqual("2016031800000002", next); next = controller.GenerateNext(sni); Assert.AreEqual("2016031800000002", next);
PS:该文已经纳入《 Rafy 用户手册》中。