愚人碼頭

          知恥而后勇,知不足而進
          隨筆 - 33, 文章 - 1, 評論 - 26, 引用 - 0
          數據加載中……

          對hibernate的新認識

                  最近項目接觸的新架構讓我對Spring和Hibernate又有了新的認識,以前使用Hibernate的時候并不是從真正的ORM角度來考慮的,我想ORM真正的目的是讓我們不需要去關注數據庫表與表之間的關系,而是考慮Entity對象之間的關系,將關注點從表與表之間轉移到對象與對象的關系上。

                  以前在使用hibernate的時候,經常由middlegen或其他工具生成Entity類后就不再改動,或者只對一些字段屬性進行改動,而現在這個架構在使用的時候,所有的entity之間的業務邏輯都是實現在entity類里面,如有Account, User, Balance這三個實體類,一個User可能有多個Account, 一個Account的對應一個Balance,如果需要添加一個新的User,同時再創建一個默認的Account, 這樣的邏輯我以前會把他們都在Service層中實現,而現在的做法是直接在User類中設置一個addAccount的方法,在createUser的時候進行調用,而創建User時則是調用一個Factory進行創建。這樣就將業務邏輯全部封裝在entity類中,除了一些查詢之外,而這寫對象也就成了domain對象。

                  當然,在客戶端調用的時候我們還是通過一個Service來調用domain對象的,這個Service是由Spring維護的,在每個service方法中都會存在Hibernate的Session,這樣在持久化的時候,只需要flush一下就可以將所有的domain對象持久化到數據庫中。在當前框架中,表現層使用的是GWT,而hibernate session則使用Spring的SessionInViewInterceptor將session一直傳播到表現層,這樣在Lazyload的時候就不會出現問題。所有domain對象的ID都是由AspectJ靜態織入,因為在使用的時候,要避免對ID進行操作,如根據ID進行查找之類的,因為ID都是無業務的主鍵。

                 在hibernate mapping file中,所有實體的關系都體現在里面,包括subclass, map,list之類的數據結構,這些結構之前我很少用到,看來對hibernate的理解還是有些差異,僅僅局限在了簡單的使用上,卻忘了其精髓----ORM,從對象的角度考慮

          posted on 2008-01-30 11:14 船夫 閱讀(1956) 評論(7)  編輯  收藏 所屬分類: java技術

          評論

          # re: 對hibernate的新認識  回復  更多評論   

          從軟件工程角度,hibernate不被提倡,它要求使用者有很高的技巧,如果是單個人沒有問題,如果是群體,這項技術就不被看好,不可能每個人都是博士.
          2008-01-30 12:13 |

          # re: 對hibernate的新認識  回復  更多評論   

          不用hibernate同樣能實現你的業務邏輯
          2008-01-30 12:38 | e

          # re: 對hibernate的新認識  回復  更多評論   

          @聽
          不是吧,Hibernate有很好的封裝,大家用起來很方便呀。
          學習的曲線也不是很陡,不用要求每個人都是專家,只要會基本的操作就OK,但一個Project里至少有一個人是這方面的專家。
          2008-01-30 13:05 | Robin's Java World

          # re: 對hibernate的新認識  回復  更多評論   

          其實hibernate在使用起來并不困難(緩存配置和事務隔離級別的設置還是需要一些全面的考慮的),真正的意義是考慮角度的改變,從我們以往的表之間的關系變成了實體類的關系
          2008-01-30 13:48 | 船夫

          # re: 對hibernate的新認識[未登錄]  回復  更多評論   

          我也認為hibernate想要用起來應該算是門檻比較低的了。只是一些復雜機制,如繼承、多對多的中間表、何時使用MAP等問題才需要專家來處理。對于一般的開發者來說專家做好了映射,培訓一下模型概念,使用起來仍舊是比較容易的一件事。
          另外,我認為lazy可以使得我們在處理業務邏輯時,不用被加載數據問題而打斷思考。這個不是其他方案可以提供的能力。
          2008-01-30 14:17 | Feng

          # re: 對hibernate的新認識  回復  更多評論   

          最主要的是穩定性的問題,如果hibernate內容表與表之間關系太多,就會出一些莫名奇妙,讓你被老板BS的問題.
          2008-01-31 12:13 | Alexander.Yu

          # re: 對hibernate的新認識  回復  更多評論   

          這種問題目前我到還沒遇見過,而且當前項目的表結構還是比較復雜的,我知道hibernate如果不進行緩存配置的話,性能有的時候會有問題,至于穩定性的問題我倒是還沒遇到過
          2008-01-31 14:13 | 船夫
          主站蜘蛛池模板: 宝鸡市| 临猗县| 青海省| 黔西| 荆门市| 巫溪县| 富源县| 兴安县| 托克托县| 林口县| 乐清市| 崇礼县| 榆社县| 株洲市| 焉耆| 穆棱市| 富蕴县| 仙游县| 高陵县| 锦州市| 永康市| 江北区| 马关县| 高邑县| 饶阳县| 衡阳县| 沙洋县| 安义县| 治县。| 绍兴县| 即墨市| 金门县| 永康市| 潞城市| 丁青县| 四会市| 江源县| 银川市| 绥宁县| 和平区| 富宁县|