数据字典基础资料窗体主键设置为自动生成流水号码解决方案

如下图所示:点【新增】按钮,报表编号为“*自动生成*”,输入其他资料,点保存自动生成报表编号。


具备条件:
1. 流水号码的字段类型为VARCHAR类型, 长度10~50位。
2. 一张表只能有一个字段可以生成流水号码。
解决方案:
1. 在Model内,将流水号码字段Attribute特性的参数isDocFieldName设置为true,
isAddorUpdate=true。
如ReportID字段的设置如下:

2. DAL层的构造器,将_UpdateSummaryKeyMode=OnlyDocumentNo,
既通知DAL,新增状态提交数据必须生成流水号码。

DAL层,重写GetNumber方法,调用GetDataSN方法生成流水号码。
C# Code:
protected override string GetNumber(DbTransaction tran)
{
string SN = DocNoTool.GetDataSN(tran, "PT", true, 6);//注意修改流水号字头!
return SN;
}
//来源:C/S框架网 | www.csframework.com | QQ:23404761
{
string SN = DocNoTool.GetDataSN(tran, "PT", true, 6);//注意修改流水号字头!
return SN;
}
//来源:C/S框架网 | www.csframework.com | QQ:23404761
3. UI层(界面)重写DoSave, DoAdd两个方法。

C# Code:
public override void DoSave(IButtonInfo sender)
{
//调用基类提供的保存方法
base.DoSaveEx(sender);
}
public override void DoAdd(IButtonInfo sender)
{
base.DoAdd(sender);
if (this.IsAddMode)
SetEditorBindingValue(txtReportID, "*自动生成*", true);
}
//来源:C/S框架网 | www.csframework.com | QQ:23404761
{
//调用基类提供的保存方法
base.DoSaveEx(sender);
}
public override void DoAdd(IButtonInfo sender)
{
base.DoAdd(sender);
if (this.IsAddMode)
SetEditorBindingValue(txtReportID, "*自动生成*", true);
}
//来源:C/S框架网 | www.csframework.com | QQ:23404761
4. 参考文档:
数据字典自动生成流水号
http://www.csframework.com/archive/1/arc-1-20121231-1970.htm
代码生成器生成的数据字典窗体可支持流水号
http://www.csframework.com/archive/9/arc-9-20150105-2187.htm
数据字典重写SaveResultEx UpdateEx方法手动控制事务自动生成流水号
http://www.csframework.com/archive/1/arc-1-20181027-2489.htm

扫一扫加微信

代码生成器生成的数据字典窗体可支持流水号
http://www.csframework.com/archive/9/arc-9-20150105-2187.htm
数据字典重写SaveResultEx UpdateEx方法手动控制事务自动生成流水号
http://www.csframework.com/archive/1/arc-1-20181027-2489.htm

扫一扫加微信


版权声明:本文为开发框架文库发布内容,转载请附上原文出处连接
NewDoc C/S框架网