明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

實戰(zhàn) .Net 數(shù)據(jù)訪問層 - 23

[摘要]u 使用現(xiàn)成的框架Ø 首選當然是.NET Framework即將正式推出的ObjectSpaces!Ø 如果希望Tot...
u 使用現(xiàn)成的框架

Ø 首選當然是.NET Framework即將正式推出的ObjectSpaces!

Ø 如果希望Total Solution,Borland ECO就是最佳選擇!



Ø 其它

n 開源項目推薦使用OPF(國外)

n 商業(yè)產(chǎn)品推薦使用Grove(國內(nèi))



u 設計自己的持久層

Ø 如果希望自己設計輪子,那么,最好的參考資料莫過于這篇文章:http://www.ambysoft.com/persistenceLayer.pdf



Ø 它山之石,可以攻玉

此處之它山,非J2EE莫屬,經(jīng)典案例Hibernate早已家喻戶曉,您還需要等待嗎?

雖然平臺不同,但優(yōu)秀的設計是大家共同的財富,.NET guys們快快行動起來吧!



Ø 代碼是永遠的老師,請多多關注這兩個.NET Open Source項目:

n OPF

n OJB.NET



l 小結

u Data Access Layer在整個系統(tǒng)架構中的位置

這是本文最后一幅示意圖,希望帶給您一些幫助:










u DAF Solution之抉擇篇

Ø 確定接口是關鍵:No. 1!

無論采用什么技術,這個總是最最關鍵的一步:至少,作者是這么認為的。



采用了DAF Solution后,其實已經(jīng)對具體使用什么Data Access Logic技術沒必要特別Care,只要接口確定,連很多歷史遺留問題都可輕松解決了!



Ø 訪問技術隨心所欲:Just Do It!

一般做項目前,當我們設計Data Access Logic時,大都需要提前決定采用什么技術架構,如:Stored Procedure + DataSet / DataTable / DataView(Duwamish模式,結構簡單,操作方便),或者SQL + Provider Factory + DataReader + Entity(PetShop模式,性能不錯,可移植能力強),而采用了DAF Solution后,這些不再成為阻礙系統(tǒng)架構師進行Data Access Logic設計時的障礙了!



你完全可以這么做:設計時全部采用Duwamish模式,而在實現(xiàn)時(可能基于性能考慮)將部分Data Access Logic操作調(diào)整為PetShop模式。甚至,如果其它Layer的調(diào)用者對ADO.NET不是特別熟悉(很正常),也可以決定在某些Data Access Logic的內(nèi)部使用O/R Mapping,通過Entity Façade返回后可以很輕松地以OO的方式進行后續(xù)處理!



不過,盡管如此,還是有些Issues需要具體情況具體分析:

(1) Stored Procedure在帶來便利、高性能的同時,也有移植上的問題需要考慮;

(2) O/R Mapping在提高易用性的同時,也為性能、復雜度付出了一定代價;

(3) 何時采用DataReader,如何更快的訪問DataSet,始終是個難以取舍的問題(雖然作者曾經(jīng)對此作過斷言),愛恨兩難!

(4) 是否使用Distributed Process?安全問題又如何解決?.NET Remoting沒有給出很好地解決方案,WebServices雖然有,但能保證與其它系統(tǒng)兼容嗎?



僅舉4例,可見一斑。

雖然這些現(xiàn)實問題都要一一解決,但在DAF這棵大樹下,您還是有較大的自由度,不必再為統(tǒng)一架構設計而頻添很多煩惱了!



Ø Storage不在話下:Data Entity Facade!

在這里,作者認為,或許稱之為“Persistence不在話下”更貼切一些。

可以這么說,DAL的基石來自DAF,而DAF和外界的Bridge則是Data Entity Façade。正是其統(tǒng)一的外表才讓我們得以自由應付隨時可能發(fā)生的各種變化!



返回XML?沒問題!

返回XML后不想修改調(diào)用代碼?很簡單,做個EntityConvert!



O/R Mapping很酷,讓我返回對象吧?改一下配置文件,再寫個

O/R Mapping Data Access Logic!是不是也很酷啊?



DataSet令我們的系統(tǒng)不堪重負,客戶最近頻繁投訴:您呼叫的

網(wǎng)頁暫時沒有應答,請稍后再刷,咋辦呢?

這也不難:撤下DataSet,換上DataReader,Data Entity

Façade已將不同的數(shù)據(jù)訪問基站構建到您的Server上,它

會確保您的系統(tǒng)99.98%位于服務區(qū)內(nèi)(還有0.01%可能是您

忘打.NET Framework的最新Patch了,剩下的0.01%也很好

辦,快去買條新內(nèi)存or加個CPU吧)!



……(如您需要返回其它系統(tǒng)無法辨認的東東,請撥打如下免費電話:800820xxxx,DAF Solution小組將為您提供幫助……)



u n-Tier架構下n之真諦

很簡單,2句話結尾:

n==?不重要,關鍵是:數(shù)據(jù)訪問層!

若要架構好,接口是命脈!



l 參考

u MSDN

Ø .NET Framework 1.2 Documentation

Ø Longhorn SDK

Ø Data Access and Storage

Ø C# 2.0 Specification

u Design Patterns

Ø GOF 23

Ø Microsoft Patterns & Practices

u Community

Ø The Microsoft .NET Framework Community

Ø TheServerSide.NET

Ø ASP.NET Starter Kits

Ø The Code Project

Ø Dot Net Persistence

u 其它

Ø Developing the Microsoft Business Framework

Ø Borland ECO

Ø Constructor

Ø DotNetNuke

Ø Rational XDE