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 ![]() 扫一扫加作者微信 ![]() ![]()
参考文档:
高级版:保存附件性能优化 支持主从表BLL单独提交明细表优化UpdateDetailKey方法|C/S框架网 Winform皮肤框架 - GridView表格样式管理器详解|C/S框架网 Winform皮肤框架之GridView表格列头右键菜单详解|C/S框架网 更新明细表的外键-优化方法UpdateDetailKey|C/S框架网 性能优化:CSFramework.WebApi获取指定日期范围以内的用户有效令牌 WebApi框架CmdLogin.Login方法返回的数据是加密的 CSFramework.WebApi后端框架Token令牌体系架构与应用详解 用户数据操作报告(frmOperateReport)窗体使用方法 SQLServer连接字符串连接池详解,Pooling=True/False区别 C#.NET GC.Collect垃圾回收机制详解 SQL Server 存储过程详解 CG_LookupDataBoundAttribute类详解 C#类扩展方法,字符串对象转换,常用扩展方法StringExtensions BLL层_DataBinder对象以及_DataBinder.Rows[0].EndEdit方法详解
其它资料:
什么是C/S结构? | C/S框架核心组成部分 | C/S框架-WebService部署图 | C/S框架-权限管理 | C/S结构系统框架 - 5.1旗舰版介绍 | C/S结构系统框架 - 功能介绍 | C/S结构系统框架 - 产品列表 | C/S结构系统框架 - 应用展示(图) | 三层体系架构详解 | C/S架构轻量级快速开发框架 | C/S框架网客户案例 | WebApi快速开发框架 | C/S框架代码生成器 | 用户授权注册软件系统 | 版本自动升级软件 | 数据库底层应用框架 | CSFramework.CMS内容管理系统 | |