适用于简单MIS系统的控件关系映射组件设计思路分享

开发 后端
文章分享了一个控件关系映射组件的设计思路。这个组件只适用于简单的MIS系统快速开发,而且由于.NET中现在有了绑定控件功能,所以这个控件现在用处有限。只是希望能够给初学者一些帮助。

MIS系统就是信息管理系统,用于信息的收集、传递、维护和使用等等。控件关系映射(Control Relation Mapping,CRM)是我在2005年研究生一年级给导师做项目的时候提出来的一种针对大表单的快速解决方案(解决方案很多种),其设计从UI映射和OR映射借鉴了点思想,加上点自己的体会设计的,不过这个组件属于业余级别的。

这个组件的设计背景是:给导师做一个项目(20万的企业MIS),MIS系统就是有一个大表单用于输入信息,实现数据库记录CRUD操作。不过这个项目表单有点夸张,少的有70~80个字段,多的有几百个,最夸张的是一个同学设计了1000多个字段的表单,他做好后,很有成就感的给显了一下。不过,我可以没有他那么有耐心,从小到大我都是偷懒过来的,因此我就在琢磨怎么省点事。整个项目有9大模块,必须采用Delphi开发(现在忘光了,我原来就没想学这玩意,Pascal语言让我感觉很别扭)。我负责框架设计和其中一个模块。框架的设计采用模块化支持,集成界面配置、权限管理、包管理、基本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概念设计图

CRM体系结构图下:

CRM体系结构图

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

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

(1)插入派遣单位表单

插入派遣单位表单

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

生成映射SQL

(3)在“保存”按钮的OnClick事件响应函数编写一行代码即可完成该功能:

MappingFactory.ExecuteMapping(this,"HumanDispSolution.SpreadFaculty.Web_DispDepart","InsertDispDepartment")。执行结果就是插入记录并记录日志。

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

【编辑推荐】

  1. .NET平台构成:操作系统,.NET框架到IDE
  2. .NET框架与COM:背景和历史,关系的发展
  3. .NET框架与XML:Web服务的未来之道
  4. Windows 7 API Code Pack介绍
  5. .NET内存映射文件原理、创建及进程通讯
责任编辑:yangsai 来源: 道法自然的博客
相关推荐

2018-10-24 10:43:13

2021-03-18 10:46:00

Linux监控工具命令

2022-11-29 08:45:44

Vue 3UI 组件库

2023-10-26 14:34:32

2013-07-23 10:05:12

UI设计交互设计

2009-11-29 17:10:01

NetgearLinux系统路由器

2022-02-10 00:16:01

开发者元宇宙系统

2022-09-02 17:47:46

Linux笔记应用

2019-08-15 15:48:30

Linux系统软件

2020-05-14 17:54:54

查看器 Linux 系统

2023-11-30 08:55:15

LinuxLibreOffic

2011-12-08 09:43:56

虚拟化vmwareVMware Fusi

2021-11-03 10:14:31

PowerEdge

2013-02-21 10:13:25

2021-12-13 12:56:26

Linux浏览器

2011-05-13 09:56:23

Ubuntu 11.0

2018-06-13 09:00:00

2024-01-23 16:48:32

2011-02-25 09:08:22

LinuxSuSE Linux
点赞
收藏

51CTO技术栈公众号