實戰(zhàn) .Net 數(shù)據(jù)訪問層 - 23
發(fā)表時間:2023-07-27 來源:明輝站整理相關軟件相關文章人氣:
[摘要]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