不入流的控件关系映射组件

简介:
控件关系映射(Control Relation Mapping,CRM)是我在2005年研究生一年级给导师做项目的时候提出来的一种针对大表单的快速解决方案(解决方案很多种),其设计从UI映射和OR映射借鉴了点思想,加上点自己的体会设计的,不过这个组件属于业余级别的。

这个组件的设计背景是:给导师做一个项目(20万的企业MIS),MIS系统就是有一个大表单用于输入信息,实现数据库记录CRUD操作。不过这个项目表单有点夸张,少的有70~80个字段,多的有几百个,最夸张的是一个同学设计了1000多个字段的表单,他做好后,很有成就感的给显了一下。不过,我可以没有他那么有耐心,从小到大我都是偷懒过来的,因此我就在琢磨怎么省点事。整个项目有9大模块,必须采用Delphi开发(现在忘光了,我原来就没想学这玩意,Pasical语言让我感觉很别扭)。我负责框架设计和其中一个模块。框架的设计采用模块化支持,集成界面配置、权限管理、包管理、基本UI操作,由框架加载各个模块(BPL库,类似DOTNET的程序集),根据需要呈现各个模块其中的UI。我负责的模块需要输入一堆数据,因此我设计了一个小型的控件关系映射(由于业务简单,没有采用ORM等先进技术),其思想非常简单,即利用一个XML封装界面的输入、处理和输出,XML文件由可视化工具自动生成。

CRM概念设计图如下,其思想是利用一个XML配置文件,实现界面表单与数据库记录映射,中心思想是一条映射SQL。映射SQL的参数来自界面控件、某个类成员或方法,或者常量;映射SQL执行数据库的操作;映射执行结果是控件属性赋值、控件赋值、成员赋值、数据绑定、调用方法等。通过映射SQL很容易实现:1 进入页面后查询,执行Bind映射SQL,填充DataGrid;2 点击添加,显示一个Panel,隐藏DG Panel,保存后,执行Create映射SQL,映射结果是隐藏添加记录Panel、显示DG Panel、执行Bind映射SQL;3 Update和Create类似。因此,在我的应用中,无论表单如何复杂,代码都不会超过100行。

CRM体系结构图下:

它由映射配置工具、映射文件、映射配置层、核心层和窗体层组成,相当于关系数据库与用户界面的适配器,为双方的数据交互提供桥梁作用。当用户输入信息提交系统后,(1)核心层利用窗体层提供的功能从用户界面获取用户数据;(2)核心层利用映射配置层读取映射配置并解析;(3)核心层利用数据访问层访问关系数据库;(4)如果本次访问需要返回结果,则核心层利用映射配置层读取配置数据,然后利用窗体层将返回结果显示给用户。如果用户仅需从关系数据库获取数据时,则只需要执行上述过程的(2)~(4)步骤。

举个非常简单的例子(基于.NET,做完Delphi项目后,我移植到DotNET 1.1了):
(1)插入派遣单位表单

(2)利用可视化配置工具生成映射SQL如下

(3)在“保存”按钮的OnClick事件响应函数编写一行代码即可完成该功能:
 MappingFactory.ExecuteMapping(this,”HumanDispSolution.SpreadFaculty.Web_DispDepart”,”InsertDispDepartment”)。执行结果就是插入记录并记录日志。

在实际应用中表单要比这复杂多了,这个小东西帮了我不少忙,在几个业余项目都用它来开发。这个小组件,只适用于简单的MIS快速开发,在DOTNET2005以后微软开始在DataSource支持绑定控件了,现在CRM.NET有点不入流了,不过还是希望对一些初学者有点帮助吧。




本文转自道法自然博客园博客,原文链接:http://www.cnblogs.com/baihmpgy/archive/2009/08/31/1557556.html,如需转载请自行联系原作者

目录
相关文章
|
监控
数据标准应用(一):落标映射关系
数据标准创建完成后,需要指定其关联的资产对象才能发挥应用价值。数据标准和资产对象的映射关系当前可以通过落标映射规则来管理;生成映射关系后,对象是否遵循了映射到的标准定义则通过落标监控评估来判断。本文为您介绍落标映射关系的分类和管理方式。
1924 0
|
开发框架 前端开发 JavaScript
浅谈前后端分离架构模式
在现在的软件架构中,前后端分离是很普遍的软件架构,让前端更加专注于UI逻辑渲染,后台专注于数据业务逻辑,而前后端数据交互的方式就是通过API接口。
3018 0
浅谈前后端分离架构模式
|
3天前
|
云安全 人工智能 自然语言处理
AI说的每一句话,都靠谱吗?
阿里云提供AI全栈安全能力,其中针对AI输入与输出环节的安全合规挑战,我们构建了“开箱即用”与“按需增强”相结合的多层次、可配置的内容安全机制。
|
9天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
4天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
412 185
|
2天前
|
数据采集 消息中间件 人工智能
跨系统数据搬运的全方位解析,包括定义、痛点、技术、方法及智能体解决方案
跨系统数据搬运打通企业数据孤岛,实现CRM、ERP等系统高效互通。伴随数字化转型,全球市场规模超150亿美元,中国年增速达30%。本文详解其定义、痛点、技术原理、主流方法及智能体新范式,结合实在Agent等案例,揭示从数据割裂到智能流通的实践路径,助力企业降本增效,释放数据价值。
|
8天前
|
人工智能 自然语言处理 安全
国内主流Agent工具功能全维度对比:从技术内核到场景落地,一篇读懂所有选择
2024年全球AI Agent市场规模达52.9亿美元,预计2030年将增长至471亿美元,亚太地区增速领先。国内Agent工具呈现“百花齐放”格局,涵盖政务、金融、电商等多场景。本文深入解析实在智能实在Agent等主流产品,在技术架构、任务规划、多模态交互、工具集成等方面进行全维度对比,结合市场反馈与行业趋势,为企业及个人用户提供科学选型指南,助力高效落地AI智能体应用。