溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何利用MIS系統(tǒng)的控件關系映射組件

發(fā)布時間:2021-06-16 14:25:54 來源:億速云 閱讀:176 作者:chen 欄目:編程語言

本篇內(nèi)容介紹了“如何利用MIS系統(tǒng)的控件關系映射組件”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

MIS系統(tǒng)就是信息管理系統(tǒng),用于信息的收集、傳遞、維護和使用等等??丶P系映射(Control Relation Mapping,CRM)是我在2005年研究生一年級給導師做項目的時候提出來的一種針對大表單的快速解決方案(解決方案很多種),其設計從UI映射和OR映射借鑒了點思想,加上點自己的體會設計的,不過這個組件屬于業(yè)余級別的。

這個組件的設計背景是:給導師做一個項目(20萬的企業(yè)MIS),MIS系統(tǒng)就是有一個大表單用于輸入信息,實現(xiàn)數(shù)據(jù)庫記錄CRUD操作。不過這個項目表單有點夸張,少的有70~80個字段,多的有幾百個,最夸張的是一個同學設計了1000多個字段的表單,他做好后,很有成就感的給顯了一下。不過,我可以沒有他那么有耐心,從小到大我都是偷懶過來的,因此我就在琢磨怎么省點事。整個項目有9大模塊,必須采用Delphi開發(fā)(現(xiàn)在忘光了,我原來就沒想學這玩意,Pascal語言讓我感覺很別扭)。我負責框架設計和其中一個模塊??蚣艿脑O計采用模塊化支持,集成界面配置、權限管理、包管理、基本UI操作,由框架加載各個模塊(BPL庫,類似DOTNET的程序集),根據(jù)需要呈現(xiàn)各個模塊其中的UI。我負責的模塊需要輸入一堆數(shù)據(jù),因此我設計了一個小型的控件關系映射(由于業(yè)務簡單,沒有采用ORM等先進技術),其思想非常簡單,即利用一個XML封裝界面的輸入、處理和輸出,XML文件由可視化工具自動生成。

CRM概念設計圖如下,其思想是利用一個XML配置文件,實現(xiàn)界面表單與數(shù)據(jù)庫記錄映射,中心思想是一條映射SQL。映射SQL的參數(shù)來自界面控件、某個類成員或方法,或者常量;映射SQL執(zhí)行數(shù)據(jù)庫的操作;映射執(zhí)行結(jié)果是控件屬性賦值、控件賦值、成員賦值、數(shù)據(jù)綁定、調(diào)用方法等。通過映射SQL很容易實現(xiàn):1 進入頁面后查詢,執(zhí)行Bind映射SQL,填充DataGrid;2 點擊添加,顯示一個Panel,隱藏DG Panel,保存后,執(zhí)行Create映射SQL,映射結(jié)果是隱藏添加記錄Panel、顯示DG Panel、執(zhí)行Bind映射SQL;3 Update和Create類似。因此,在我的應用中,無論表單如何復雜,代碼都不會超過100行。

如何利用MIS系統(tǒng)的控件關系映射組件

CRM體系結(jié)構(gòu)圖下:

如何利用MIS系統(tǒng)的控件關系映射組件

它由映射配置工具、映射文件、映射配置層、核心層和窗體層組成,相當于關系數(shù)據(jù)庫與用戶界面的適配器,為雙方的數(shù)據(jù)交互提供橋梁作用。當用戶輸入信息提交系統(tǒng)后,(1)核心層利用窗體層提供的功能從用戶界面獲取用戶數(shù)據(jù);(2)核心層利用映射配置層讀取映射配置并解析;(3)核心層利用數(shù)據(jù)訪問層訪問關系數(shù)據(jù)庫;(4)如果本次訪問需要返回結(jié)果,則核心層利用映射配置層讀取配置數(shù)據(jù),然后利用窗體層將返回結(jié)果顯示給用戶。如果用戶僅需從關系數(shù)據(jù)庫獲取數(shù)據(jù)時,則只需要執(zhí)行上述過程的(2)~(4)步驟。

舉個非常簡單的例子(基于.NET,做完Delphi項目后,我移植到DotNET 1.1了):

(1)插入派遣單位表單

如何利用MIS系統(tǒng)的控件關系映射組件

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

如何利用MIS系統(tǒng)的控件關系映射組件

(3)在“保存”按鈕的OnClick事件響應函數(shù)編寫一行代碼即可完成該功能:

MappingFactory.ExecuteMapping(this,"HumanDispSolution.SpreadFaculty.Web_DispDepart","InsertDispDepartment")。執(zhí)行結(jié)果就是插入記錄并記錄日志。

在實際應用中表單要比這復雜多了,這個小東西幫了我不少忙,在幾個業(yè)余項目都用它來開發(fā)。這個小組件,只適用于簡單的MIS系統(tǒng)快速開發(fā),在DOTNET2005以后微軟開始在DataSource支持綁定控件了,現(xiàn)在CRM.NET有點不入流了,不過還是希望對一些初學者有點幫助吧。

“如何利用MIS系統(tǒng)的控件關系映射組件”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI