中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)絡(luò)編程 > .NET業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 后篇
.NET 分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(五) 回到列表 .NET分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(四) 中篇
 .NET業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 后篇

作者:小洋 時間: 2010-06-28 文檔類型:轉(zhuǎn)載 來自:博客園

第 1 頁 .NET業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 后篇 [1]
第 2 頁 .NET業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 后篇 [2]

NET 業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 中篇—— 業(yè)務(wù)層初步構(gòu)想

前言

本篇主要講述如何把DAL和BLL銜接起來。

本篇議題如下

1).DAL和BLL之前的Mapping

2).如何Mapping

3).再次構(gòu)思

1.DAL和BLL之前的Mapping

首先,業(yè)務(wù)類和數(shù)據(jù)實(shí)體類不是一 一對應(yīng)的關(guān)系,換句話說,不是一個業(yè)務(wù)類就一定對應(yīng)數(shù)據(jù)庫中的一張表。業(yè)務(wù)類是用只是使用數(shù)據(jù)實(shí)體中的數(shù)據(jù)而已,所以一個業(yè)務(wù)類中的數(shù)據(jù)往往來自多個數(shù)據(jù)實(shí)體。

每個業(yè)務(wù)類都是有自己的一些屬性的,把數(shù)據(jù)以數(shù)據(jù)實(shí)體或者DataTable的形式從DAL獲取之后,BLL類就使用這些數(shù)據(jù),BLL不會把這些原生的數(shù)據(jù)實(shí)體暴露給UI。BLL類會把UI中要是用的數(shù)據(jù)裝入到自己的屬性中。

所以在這個過程中就有一個賦值的過程,或者稱為mapping映射。當(dāng)Richard提出這個想法后,項(xiàng)目組的同事就問他:為什么要做的這么復(fù)雜,還要一 一 的賦值,為什么不直接把數(shù)據(jù)實(shí)體給UI使用,為什么一定要在中間這么轉(zhuǎn)一下呢?

Richard分析了一些原因

1. 如果直接把數(shù)據(jù)實(shí)體給了UI,那么UI那端就很清楚DAL了,以后數(shù)據(jù)訪問方式從ADO.NET 到了EF,那么UI 就動了,又回到以前了。

2.在BLL中可以對從DAL取出來的數(shù)據(jù)進(jìn)行一些處理,如轉(zhuǎn)換格式,計算,組合等。

Richard想到把BLL和DAL徹底的解耦:業(yè)務(wù)類中不存在數(shù)據(jù)實(shí)體類的引用。這樣設(shè)計之后靈活性就很大了。最后達(dá)到的效果就是:通過配置,配置業(yè)務(wù)類每個屬性的數(shù)據(jù)的來源。而這個業(yè)務(wù)類完全不知道這些數(shù)據(jù)到底來源于哪個或者哪些數(shù)據(jù)實(shí)體。

這樣確實(shí)很靈活,Richard興奮不已。

2. 如何Mapping

初步想法通過配置文件。如現(xiàn)在有一個Product的業(yè)務(wù)類,定義如下:

代碼 

public class ProductBL
    {
        public string ProductName { get; set; }
        public decimal Price { get; set; }
        public string Description { get; set; }      
    }

那么如何給這些屬性賦值,同時也不引用數(shù)據(jù)實(shí)體。Richard用配置文件來實(shí)現(xiàn)的,這里Richard就約定了:配置文件的名字就是“業(yè)務(wù)類的名字”+“Mapping.xml”.所以Product的配置文件就是ProductBLMapping.xml

代碼

<?xml version="1.0" encoding="utf-8" ?>
<BusinessModel name="ProductBL" mappingTo="DAL.ProductEntity" >
  <property name="ProductName" mappingTo="Name" type="System.String"/>
  <property name="Price" mappingTo="Price" type="System.Decimal"/>
  <property name="Description" mappingTo="Description" type="System.String"/>
</BusinessModel>

然后再運(yùn)行的時候就通過反射來賦值。

現(xiàn)在問題又來了

1).每次都是通過反射來賦值,性能很成問題。

2).如果配置文件出錯,調(diào)試很不方便。

3).如何處理一個業(yè)務(wù)類對應(yīng)對個數(shù)據(jù)實(shí)體的情況,如:

代碼 

public class ProductBL
    {
        public string ProductName { get; set; }
        public decimal Price { get; set; }
        public string Description { get; set; }
        //來自CustomDAL
        public string CustomerName { get; set; }
    }

但是好處很明顯

1).DAL和BLL解耦

2).很便于查詢對象的實(shí)現(xiàn)。例如:在UI代碼寫:

ICriteria condition=CriteriaFactory.Create(typeof(ProductBL).Where("ProductName", Operation.Equal,"book");

當(dāng)然ProductName是業(yè)務(wù)類ProductBL的屬性,在查詢對象最后解析為SQL語句的時候就可以利用ProductBLMapping.xml來生成SQL。

(注:小洋請大家想想,上面的思想來自于.NET中哪個開源框架?)

對于性能方面,Richard嘗試這樣解決:

在第一次Mapping的時候,就把這些mapping的信息保存在靜態(tài)字典中,下次在mapping的時候,就不用再讀配置文件了,而且讀內(nèi)存中的字典。

但是這樣,隨著業(yè)務(wù)類的增加,內(nèi)存使用也加大,而且賦值方式還是反射。

3. 再次構(gòu)思

Richard接著考慮:如何處理一個業(yè)務(wù)類對應(yīng)對個數(shù)據(jù)實(shí)體的情況?于是配置文件就改為了:

代碼

<?xml version="1.0" encoding="utf-8" ?>
<BusinessModel name="ProductBL" >
  <property name="ProductName" mappingTo="DAL.ProductEntityName" type="System.String"/>
  <property name="Price" mappingTo="DAL.ProductEntityPrice" type="System.Decimal"/>
  <property name="Description" mappingTo="DAL.ProductEntityDescription" type="System.String"/>
  <property name="CustomerName" mappingTo="DAL.CustomerEntity.Name" type="System.String"/>
</BusinessModel>

基本的問題算是解決了,但是性能的問題依然存在。

Richard又開始考慮更加好的方式。

本篇就寫到這里,謝謝各位。

下篇: .NET 業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之八 業(yè)務(wù)層Mapping的選擇策略

權(quán)為小洋和博客園所有,轉(zhuǎn)載請標(biāo)明出處給作者。 

 http://www.cnblogs.com/yanyangtian

原文:

http://www.cnblogs.com/yanyangtian/archive/2010/06/07/1752921.html

出處:博客園
責(zé)任編輯:bluehearts

上一頁 下一頁 .NET業(yè)務(wù)框架開發(fā)實(shí)戰(zhàn)之四 后篇 [2]

◎進(jìn)入論壇網(wǎng)絡(luò)編程版塊參加討論

作者文章 更多作者文章
asp.net架構(gòu)設(shè)計解惑
.NET 分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(五)
.NET分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(四) 中篇
.NET分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(四) 前篇
.NET 分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(三)
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗(yàn) UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點(diǎn)最新 站點(diǎn)最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗(yàn)設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機(jī)會
阿里行云
云手機(jī)年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機(jī)主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機(jī)制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項(xiàng)目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:1/21個記錄/頁 轉(zhuǎn)到 頁 共2個記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨(dú)家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點(diǎn)的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點(diǎn)的水印,亦不能抹去我站點(diǎn)水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項(xiàng)有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實(shí)踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2