這樣寫,沒有錯(cuò)。但是有一點(diǎn)引起了Richard的思考:DAL類中,很多的方法基本上都是查詢的方法,而Add, Update, Delete在很多的DAL類中形式都比較的統(tǒng)一,特別是在使用了Linq, Entity Framework之后,所有的數(shù)據(jù)實(shí)體類Add,Update, Delete方法幾乎是一樣的,如在Linq中可以使用DataContext.GetTable<T>().InsertOnSubmit(entity)方法來插入任何的數(shù)據(jù)實(shí)體類。
但是就只有這些不同條件的查詢方法很難統(tǒng)一,幾乎是每個(gè)不同的DAL都要去實(shí)現(xiàn)自己的一些特有的查詢方法。但是Richard認(rèn)為把這些方法統(tǒng)一是有可能的,甚至是達(dá)到那種“以不變應(yīng)萬變的”效果才好,帶著這個(gè)想法Richard開始進(jìn)行很多的嘗試。
3. 思維的一點(diǎn)突破
Richard極力的在自己的腦海搜尋解決的方案,也翻閱自己之前下載和買過的書籍,看看那些是否與查詢數(shù)據(jù)有關(guān),只要看到有“查詢”兩個(gè)字的章節(jié),Richard就不會(huì)放過。也參看了.NET的一個(gè)知名開源Framework 的設(shè)計(jì)思想。
給了他提示的就是Fowler<<企業(yè)應(yīng)用架構(gòu)模式>>一書,書中提到的查詢對(duì)象(Query Object), Richard參看了之后第一反應(yīng)就是:確實(shí)不錯(cuò),但是太抽象了,沒有給出一些示例。
其實(shí)之前Richard在看這本書的時(shí)候,認(rèn)為書的高度太高了,Richard幾次攻讀,都是深受打擊。所以,結(jié)果是Richard很敬畏這本書,但是還是想有朝一日能夠拿下它,F(xiàn)在書中就有了查詢對(duì)象的一些解決方案和實(shí)現(xiàn),Richard硬著上了。
Richard認(rèn)為:很多的事情不是等你的所有條件都具備才去做的,事情往往是在你還沒有準(zhǔn)備好的情況下就已經(jīng)發(fā)生了,凡事都有一個(gè)開頭,做架構(gòu)也是這樣的,開始設(shè)計(jì)一個(gè)架構(gòu)的時(shí)候,并且不是說明你已經(jīng)完全的把所有技術(shù)都掌握了,完美了,肯定是有一個(gè)開始嘗試的過程。可能在開始設(shè)計(jì)的時(shí)候,漏洞百出,但是思維的周密性也是這樣慢慢的鍛煉出來的。
平時(shí)在思考的時(shí)候,自己站在一個(gè)高一點(diǎn)的角度看問題(現(xiàn)在是開發(fā)人員,但是開發(fā)人員在設(shè)計(jì)和開發(fā)的時(shí)候可以這樣想:如果我是架構(gòu)的設(shè)計(jì)者,我會(huì)怎么做?),思維的高度上去了,機(jī)會(huì)到來的時(shí)候也就從容了。
Richard開始重新理解查詢對(duì)象。其實(shí)查詢對(duì)象就是在一定程度上隱藏了SQL語句,查詢對(duì)象是解釋器模式的一種應(yīng)用,實(shí)際上查詢對(duì)象最后還是要解釋為SQL語句到數(shù)據(jù)庫中去執(zhí)行的(不管在中間過程是如何一步步的操作這個(gè)查詢對(duì)象,因?yàn)閿?shù)據(jù)庫現(xiàn)在只是認(rèn)識(shí)SQL,所以查詢對(duì)象最終還是要生成SQL語句)。
查詢對(duì)象主要用途就是使得客戶程序可以構(gòu)造各種的查詢,而且查詢中使用的都是與業(yè)務(wù)類有關(guān)的屬性,這就意味著,客戶程序不用了解數(shù)據(jù)庫的表名和列名。這種做法最直接的好處就是業(yè)務(wù)開發(fā)的人員不用知道數(shù)據(jù)庫的構(gòu)造。
而且如果查詢對(duì)象的設(shè)計(jì)是以接口的形式出現(xiàn),那么靈活性就更加的大。例如,設(shè)計(jì)一個(gè)IQuery的查詢對(duì)象接口,然后,在架構(gòu)中有兩個(gè)實(shí)現(xiàn)
了IQuery接口的查詢對(duì)象,如LinqQuery, EFQuery,這兩個(gè)具體的查詢對(duì)象最終會(huì)被分別解釋為Linq和Entity Framework可以識(shí)別的語句,再通過Linq和Entity Framework去執(zhí)行數(shù)據(jù)操作。在程序中就可以通過配置來決定使用哪種查詢對(duì)象和使用哪種數(shù)據(jù)訪問技術(shù)。
越來越多的想法在Richard的腦海中出現(xiàn),而隨之帶來的問題也開始堆積;镜乃枷胧怯辛,但是實(shí)現(xiàn)起來那就得是另外的一回事了。怎么把這些思緒理清,怎么把這些理清的思緒變?yōu)榇a的實(shí)現(xiàn),這個(gè)成為了擺在Richard面前最現(xiàn)實(shí)的難題。
但是不管怎樣,已經(jīng)有了一點(diǎn)點(diǎn)的進(jìn)展,記得當(dāng)初考慮的時(shí)候還是頭腦一片空白,現(xiàn)在的想法一個(gè)接著一個(gè),在思維上進(jìn)步了。Richard覺得有點(diǎn)欣慰。
4.回首再看數(shù)據(jù)訪問層
有了上面的思考,Richard再次審視了DAL,開始發(fā)覺:DAL其實(shí)就只是一個(gè)存取數(shù)據(jù)和操作數(shù)據(jù)的地方,這就是DAL的主要功能,F(xiàn)在數(shù)據(jù)層的設(shè)計(jì)基本上已經(jīng)可以實(shí)現(xiàn)了,而且可以做到“以不變應(yīng)萬變”,不管BLL中對(duì)數(shù)據(jù)進(jìn)行什么樣的操作,在DAL層都可以用那個(gè)四種增,刪,查,改的方法搞定。
本篇就到這里,謝謝各位!
下篇講述: .NET 分布式架構(gòu)開發(fā)實(shí)戰(zhàn)之四 構(gòu)建從理想和實(shí)現(xiàn)之間的橋梁 版權(quán)為小洋和博客園所有,轉(zhuǎn)載請(qǐng)標(biāo)明出處給作者。
http://www.cnblogs.com/yanyangtian
轉(zhuǎn)載:http://www.cnblogs.com/yanyangtian/archive/2010/05/26/1744064.html
本文鏈接:http://www.95time.cn/tech/program/2010/7753.asp
出處:博客園
責(zé)任編輯:bluehearts
上一頁 .NET 分布式架構(gòu)開發(fā)實(shí)戰(zhàn)(三) [1] 下一頁
◎進(jìn)入論壇網(wǎng)絡(luò)編程版塊參加討論
|