您好,登錄后才能下訂單哦!
本篇內容介紹了“如何利用MIS系統的控件關系映射組件”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
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體系結構圖下:
它由映射配置工具、映射文件、映射配置層、核心層和窗體層組成,相當于關系數據庫與用戶界面的適配器,為雙方的數據交互提供橋梁作用。當用戶輸入信息提交系統后,(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有點不入流了,不過還是希望對一些初學者有點幫助吧。
“如何利用MIS系統的控件關系映射組件”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。