<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

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

      實戰 .Net 數據訪問層 - 23

      [摘要]u 使用現成的框架&Oslash; 首選當然是.NET Framework即將正式推出的ObjectSpaces!&Oslash; 如果希望Tot...
      u 使用現成的框架

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

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



      &Oslash; 其它

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

      n 商業產品推薦使用Grove(國內)



      u 設計自己的持久層

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



      &Oslash; 它山之石,可以攻玉

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

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



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

      n OPF

      n OJB.NET



      l 小結

      u Data Access Layer在整個系統架構中的位置

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










      u DAF Solution之抉擇篇

      &Oslash; 確定接口是關鍵:No. 1!

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



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



      &Oslash; 訪問技術隨心所欲:Just Do It!

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



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



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

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

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

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

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



      僅舉4例,可見一斑。

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



      &Oslash; Storage不在話下:Data Entity Facade!

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

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



      返回XML?沒問題!

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



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

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



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

      網頁暫時沒有應答,請稍后再刷,咋辦呢?

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

      Fa&ccedil;ade已將不同的數據訪問基站構建到您的Server上,它

      會確保您的系統99.98%位于服務區內(還有0.01%可能是您

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

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



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



      u n-Tier架構下n之真諦

      很簡單,2句話結尾:

      n==?不重要,關鍵是:數據訪問層!

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



      l 參考

      u MSDN

      &Oslash; .NET Framework 1.2 Documentation

      &Oslash; Longhorn SDK

      &Oslash; Data Access and Storage

      &Oslash; C# 2.0 Specification

      u Design Patterns

      &Oslash; GOF 23

      &Oslash; Microsoft Patterns & Practices

      u Community

      &Oslash; The Microsoft .NET Framework Community

      &Oslash; TheServerSide.NET

      &Oslash; ASP.NET Starter Kits

      &Oslash; The Code Project

      &Oslash; Dot Net Persistence

      u 其它

      &Oslash; Developing the Microsoft Business Framework

      &Oslash; Borland ECO

      &Oslash; Constructor

      &Oslash; DotNetNuke

      &Oslash; Rational XDE




      日韩精品一区二区三区高清