bllBaseDataDict.CreateDataBinder方法详解及性能优化
作者:C/S框架网  发布日期:2015-01-07 22:20:42
  bllBaseDataDict.CreateDataBinder方法详解及性能优化



CreateDataBinder方法用于创建绑定输入框的数据源(如下图), 在界面进行查看、新增、修改,及进行删除操作后显示下一条记录时会调用此方法。基于性能优化,按以下步骤进行操作:

1. 若sourceRow参数为空且查询表格有缓存数据(_SummaryTable<>null),首先克隆缓存表,然后插入一条空记录作为新增状态下的数据源。
2. 若缓存表无数据,只能从数据库取空表,然后插入一条空记录作为新增状态下的数据源。
3  若提供sourceRow参数,获取其主键,然后数据库获取最新数据作为查看或修改状态下的数据源。

贴图图片


C# Code:

/// <summary>
/// 创建用于绑定输入控件的数据源,基于性能优化首先克隆缓存表,然后插入一条空记录作为新增状态下的数据源。
/// 若缓存表无数据,只能从数据库取空表,然后插入一条空记录作为新增状态下的数据源。
/// 若提供sourceRow参数,获取其主键,然后数据库获取最新数据作为查看或修改状态下的数据源。
/// </summary>
/// <param name="sourceRow">主表表格的当前记录</param>
public virtual void CreateDataBinder(DataRow sourceRow)
{
   if (sourceRow == null)
   {
      if (_SummaryTable != null)
      {
         _DataBinder = _SummaryTable.Clone();
         _DataBinder.Rows.Add(_DataBinder.NewRow());//插入一条空记录
      }
      else
      {
         _DataBinder = this.GetDataByKey("-");//只能从数据库取空表
         _DataBinder.Rows.Add(_DataBinder.NewRow());//插入一条空记录
      }
   }
   else
   {
      string key = ConvertEx.ToString(sourceRow[_KeyFieldName]);//获取主键
      _DataBinder = this.GetDataByKey(key);//从数据库获取最新数据
   }
}


//来源:C/S框架网(www.csframework.com) QQ:1980854898



上一篇 下一篇