The Repository Pattern

原文:https://msdn.microsoft.com/en-us/library/ff649690.aspx

Context:

在很多應用程序中,業(yè)務邏輯從數(shù)據(jù)存儲(例如數(shù)據(jù)庫,web)中訪問數(shù)據(jù),直接訪問數(shù)據(jù)可能會造成這樣的后果:

1.重復編碼

2.編程錯誤的可能性增大

3.弱類型的業(yè)務數(shù)據(jù)//強弱類型的區(qū)別就是類型安全檢查,內(nèi)存檢查,動態(tài) 靜態(tài)類型檢查

4.難以集中管理數(shù)據(jù)相關的策略(如緩存)

5.難以讓業(yè)務邏輯隔離外部依賴去進行測試

解決方法:

? ? ? ? Use a repository to separate the logic that retrieves the data and maps it to the entity model from the business logic that acts on the model(使用倉庫將檢索數(shù)據(jù)和實體模型的映射與作用于實體的的業(yè)務邏輯分離).業(yè)務邏輯應該與包含此數(shù)據(jù)的數(shù)據(jù)層實現(xiàn)無關,比如說,數(shù)據(jù)層可以是數(shù)據(jù)庫,一個網(wǎng)絡服務等。

? ? ? ? 程序中的repository應該是在數(shù)據(jù)層和業(yè)務邏輯層中間,它從數(shù)據(jù)層查詢數(shù)據(jù),將數(shù)據(jù)從數(shù)據(jù)源映射到業(yè)務實體,并將業(yè)務實體的更改保留到數(shù)據(jù)源。存儲庫將業(yè)務邏輯與與底層數(shù)據(jù)源或Web服務的交互分離。數(shù)據(jù)層和業(yè)務層之間的分離有三個好處:

1.集中了數(shù)據(jù)邏輯或web服務訪問邏輯

2.It provides a substitution point for the unit tests.(為單元測試提供了一個替代點)

3.提供了一種靈活的架構,可以隨著程序的整體設計的發(fā)展而進行調(diào)整


repository有兩種方法去查詢業(yè)務實體:

? 1.它可以向客戶端的業(yè)務邏輯提交查詢對象

? 2.他可以使用指定業(yè)務標準的方法

在第二種情況下,repository代表客戶端進行查詢。repository返回一組滿足查詢的實體集合。下圖顯示了repository與客戶端和數(shù)據(jù)源的交互:

客戶端為了實現(xiàn)持久性存儲給repository提交新的或更改過的實體,在復雜的情況下,客戶端業(yè)務邏輯可以使用工作單元模式,這種模式展示了如何封裝彼此一致或具有相關依賴關系的幾個相關操作。已經(jīng)封裝好的項會被發(fā)送到repository去進行更新或刪除,本指南不包括工作單元模式的示例。

repository是不同的域(domain)中數(shù)據(jù)和操作之間的橋梁。

一個常見的例子就是將一個弱類型數(shù)據(jù)的域(數(shù)據(jù)庫,SharePoint list)映射到一個強數(shù)據(jù)類型的域中(域中實體模型)。

一個典型的例子就是數(shù)據(jù)庫使用IDbCommand對象執(zhí)行查詢并返回一個IDataReader的對象.

另一個例子就是SharePoint,使用SPQuery對象去返回SPListItem的集合。repository向數(shù)據(jù)源發(fā)出正確的查詢,查詢結束后將結果集映射到外部的業(yè)務實體。repository通常使用Data Mapper(數(shù)據(jù)映射)模式在表示層之間進行轉換。它移除了客戶端對指定技術的依賴關系。比如說,如果客戶端調(diào)用目錄倉庫去獲取產(chǎn)品數(shù)據(jù),它只需要調(diào)用倉庫的商品目錄接口(catalog repository interface)。再比方說,客戶端不需要知道商品信息是通過SQL查詢語句從數(shù)據(jù)庫中查詢的還是通過協(xié)作應用標記語言(Collaborative Application Markup Language (CAML))從Sharepoint列表查詢的。隔離這些類型的依賴性提供了一種實現(xiàn)的靈活性。

實施細節(jié):

這部分論述了SharePoint列表庫和Web服務庫的實現(xiàn)策略.

SharePoint:

此部分略。與安卓無關。

Web服務庫:

? ? ? ?一個常見的數(shù)據(jù)后臺存儲是由line-of-business(LOB)應用程序公開的商業(yè)服務。通常來說,這些商業(yè)服務是對于普通數(shù)據(jù)庫CRUD操作更高層次的抽象。然而,從客戶端的角度來說,

? ? ? ? ? 他們通常等同于數(shù)據(jù)源。與SharePoint列表相似,訪問網(wǎng)絡服務可以是復雜并且容易出錯的。通過使用repository集中訪問服務的邏輯并且提供一個單元測試的替代點。請注意,服務的調(diào)用通常很昂貴,并且受益于在repository實現(xiàn)的緩存策略。(也就是通過本地緩存減少服務的調(diào)用)

下圖展示了使用緩存的服務后端存儲庫:


? ? ? ?在這種情況下,repository的查詢邏輯先檢查緩存中是否有需要的數(shù)據(jù),如果沒有,repository訪問網(wǎng)絡服務區(qū)獲取信息。雖然可以直接訪問服務,但也可以通過SharePoint的業(yè)務數(shù)據(jù)目錄去訪問(SharePoint Business Data Catalog (BDC))。BDC可以合并一些數(shù)據(jù)源(包括網(wǎng)絡服務),然后通過統(tǒng)一通用的接口暴露它們。BDC允許你去使用標準的網(wǎng)絡不見去展示或修改數(shù)據(jù)。

Repository Examples:

略。

注意事項:

Repository模式增加了你代碼中的抽象層次。這會導致你的代碼難以被你的同事去理解,盡管實現(xiàn)該模式減少了代碼冗余,但他通常會增加需要被維護的類的數(shù)量。

Repository模式幫助我們?nèi)ジ綦x服務和列表訪問的代碼。通過這種隔離,更容易將它們視為獨立的服務,并在單元測試當中用模擬對象去替代它們。通常來說,很難對repository本身進行單元測試,所以盡量去為他們編寫集成測試。

當你在多線程環(huán)境中緩存數(shù)據(jù)時,除了緩存對象之外,還要考慮同步對緩存的訪問呢。一般來說,常見緩存(ASP.NET的緩存),是線程安全的,但你也要確保對象自身可以在多線程環(huán)境中操作。

如果你在高負載系統(tǒng)中緩存數(shù)據(jù),性能可能是一個問題,嘗試對數(shù)據(jù)源進行同步訪問,這確保了只有單個數(shù)據(jù)請求被發(fā)送到列表或后臺服務。其他的客戶端依賴于檢索的數(shù)據(jù)。

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,546評論 6 533
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,570評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,505評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,017評論 1 313
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,786評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,219評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,287評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,438評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,971評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,796評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,995評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,540評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,230評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,918評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,697評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374

推薦閱讀更多精彩內(nèi)容