讓我忍不住跳出來新開一帖討論(觀點不一定正確,還是嘗試中),
我是同意buuawhl的,不過可能出發點不一樣。
buuawhl 寫道
組合子不錯,不過用錯了地方。
SQL拼裝采用組合子(比如包括Hibernate Criteria)這種思路,完全是畫蛇添足,一無是處,成事不足,敗事有余。
我是傾向于DDD中提出的selection的Specification的手段。
我們工作的目標是什么:selection的查詢邏輯。
換句話說我們是組合查詢邏輯的。不過是因為repository是數據庫類型,因而內部需要組合sql語句。
那么組合的對象應該是更高一層抽象的specification,而不是sql的對象化形式expression,
而這樣做兩個好處是:
第一,解決了dao的在設計分層中的尷尬地位。典型的分層體系如appfuse,
查詢本身是一種邏輯,而dao獨立層次的存在把不同的查詢logic來了個大集中,這樣的用法就很尷尬。
而如springside則好些,雖然把dao作為service來用,但是criteria的組裝獨立于dao之外。
而DDD提出的Specification,就很好的解決的這一分層問題。
第二,提供了一定的函數式編程能力(組合子編程), 提供三種簡單的操作and, or和not.
我以為DDD在這里不考慮去組合基本的Expression,
而是從業務角度考慮,組合的是specification,返回的是domain object list(這樣更是顯示的和sql中的projection區別開)
當然這樣的組合能力可能不強,不過基本可用(本句話未經驗證,還沒有來得及做)。
至于內部即便是用sql也是可以的,如果覺得被"污染"了(buuawhl老大語錄),就參考ibatis的思路做。
安徽新華電腦學校專業職業規劃師為你提供更多幫助【在線咨詢】